/** layui-v2.5.5 MIT License By  */
;
!function (e) {
    'use strict';
    var t = document,
        o = {
            modules: {},
            status: {},
            timeout: 10,
            event: {}
        },
        n = function () {
            this.v = '2.5.5'
        },
        r = function () {
            var e = t.currentScript ? t.currentScript.src : function () {
                for (var e, o = t.scripts, n = o.length - 1, r = n; r > 0; r--) if ('interactive' === o[r].readyState) {
                    e = o[r].src;
                    break
                }
                return e || o[n].src
            }();
            return e.substring(0, e.lastIndexOf('/') + 1)
        }(),
        i = function (t) {
            e.console && console.error && console.error('Layui hint: ' + t)
        },
        a = 'undefined' != typeof opera && '[object Opera]' === opera.toString(),
        u = {
            layer: 'modules/layer',
            laydate: 'modules/laydate',
            laypage: 'modules/laypage',
            laytpl: 'modules/laytpl',
            layim: 'modules/layim',
            layedit: 'modules/layedit',
            form: 'modules/form',
            upload: 'modules/upload',
            transfer: 'modules/transfer',
            tree: 'modules/tree',
            table: 'modules/table',
            element: 'modules/element',
            rate: 'modules/rate',
            colorpicker: 'modules/colorpicker',
            slider: 'modules/slider',
            carousel: 'modules/carousel',
            flow: 'modules/flow',
            util: 'modules/util',
            code: 'modules/code',
            jquery: 'modules/jquery',
            mobile: 'modules/mobile',
            'layui.all': '../layui.all'
        };
    n.prototype.cache = o,
        n.prototype.define = function (e, t) {
            var n = this,
                r = 'function' == typeof e,
                i = function () {
                    var e = function (e, t) {
                        layui[e] = t,
                            o.status[e] = !0
                    };
                    return 'function' == typeof t && t(function (n, r) {
                        e(n, r),
                            o.callback[n] = function () {
                                t(e)
                            }
                    }),
                        this
                };
            return r && (t = e, e = []),
                !layui['layui.all'] && layui['layui.mobile'] ? i.call(n) : (n.use(e, i), n)
        },
        n.prototype.use = function (e, n, l) {
            function s(e, t) {
                var n = 'PLaySTATION 3' === navigator.platform ? /^complete$/ : /^(complete|loaded)$/;
                ('load' === e.type || n.test((e.currentTarget || e.srcElement).readyState)) && (o.modules[f] = t, d.removeChild(v), function r() {
                    return ++m > 1000 * o.timeout / 4 ? i(f + ' is not a valid module') : void (o.status[f] ? c() : setTimeout(r, 4))
                }())
            }

            function c() {
                l.push(layui[f]),
                    e.length > 1 ? y.use(e.slice(1), n, l) : 'function' == typeof n && n.apply(layui, l)
            }

            var y = this,
                p = o.dir = o.dir ? o.dir : r,
                d = t.getElementsByTagName('head') [0];
            e = 'string' == typeof e ? [
                e
            ] : e,
            window.jQuery && jQuery.fn.on && (y.each(e, function (t, o) {
                'jquery' === o && e.splice(t, 1)
            }), layui.jquery = layui.$ = jQuery);
            var f = e[0],
                m = 0;
            if (l = l || [], o.host = o.host || (p.match(/\/\/([\s\S]+?)\//) || [
                '//' + location.host + '/'
            ]) [0], 0 === e.length || layui['layui.all'] && u[f] || !layui['layui.all'] && layui['layui.mobile'] && u[f]) return c(),
                y;
            if (o.modules[f]) !function g() {
                return ++m > 1000 * o.timeout / 4 ? i(f + ' is not a valid module') : void ('string' == typeof o.modules[f] && o.status[f] ? c() : setTimeout(g, 4))
            }();
            else {
                var v = t.createElement('script'),
                    h = (u[f] ? p + 'lay/' : /^\{\/\}/.test(y.modules[f]) ? '' : o.base || '') + (y.modules[f] || f) + '.js';
                h = h.replace(/^\{\/\}/, ''),
                    v.async = !0,
                    v.charset = 'utf-8',
                    v.src = h + function () {
                        var e = o.version === !0 ? o.v || (new Date).getTime() : o.version || '';
                        return e ? '?v=' + e : ''
                    }(),
                    d.appendChild(v),
                    !v.attachEvent || v.attachEvent.toString && v.attachEvent.toString().indexOf('[native code') < 0 || a ? v.addEventListener('load', function (e) {
                        s(e, h)
                    }, !1) : v.attachEvent('onreadystatechange', function (e) {
                        s(e, h)
                    }),
                    o.modules[f] = h
            }
            return y
        },
        n.prototype.getStyle = function (t, o) {
            var n = t.currentStyle ? t.currentStyle : e.getComputedStyle(t, null);
            return n[n.getPropertyValue ? 'getPropertyValue' : 'getAttribute'](o)
        },
        n.prototype.link = function (e, n, r) {
            var a = this,
                u = t.createElement('link'),
                l = t.getElementsByTagName('head') [0];
            'string' == typeof n && (r = n);
            var s = (r || e).replace(/\.|\//g, ''),
                c = u.id = 'layuicss-' + s,
                y = 0;
            return u.rel = 'stylesheet',
                u.href = e + (o.debug ? '?v=' + (new Date).getTime() : ''),
                u.media = 'all',
            t.getElementById(c) || l.appendChild(u),
                'function' != typeof n ? a : (function p() {
                    return ++y > 1000 * o.timeout / 100 ? i(e + ' timeout') : void (1989 === parseInt(a.getStyle(t.getElementById(c), 'width')) ? function () {
                        n()
                    }() : setTimeout(p, 100))
                }(), a)
        },
        o.callback = {},
        n.prototype.factory = function (e) {
            if (layui[e]) return 'function' == typeof o.callback[e] ? o.callback[e] : null
        },
        n.prototype.addcss = function (e, t, n) {
            return layui.link(o.dir + 'css/' + e, t, n)
        },
        n.prototype.img = function (e, t, o) {
            var n = new Image;
            return n.src = e,
                n.complete ? t(n) : (n.onload = function () {
                    n.onload = null,
                    'function' == typeof t && t(n)
                }, void (n.onerror = function (e) {
                    n.onerror = null,
                    'function' == typeof o && o(e)
                }))
        },
        n.prototype.config = function (e) {
            e = e || {};
            for (var t in e) o[t] = e[t];
            return this
        },
        n.prototype.modules = function () {
            var e = {};
            for (var t in u) e[t] = u[t];
            return e
        }(),
        n.prototype.extend = function (e) {
            var t = this;
            e = e || {};
            for (var o in e) t[o] || t.modules[o] ? i('模块名 ' + o + ' 已被占用') : t.modules[o] = e[o];
            return t
        },
        n.prototype.router = function (e) {
            var t = this,
                e = e || location.hash,
                o = {
                    path: [],
                    search: {},
                    hash: (e.match(/[^#](#.*$)/) || []) [1] || ''
                };
            return /^#\//.test(e) ? (e = e.replace(/^#\//, ''), o.href = '/' + e, e = e.replace(/([^#])(#.*$)/, '$1').split('/') || [], t.each(e, function (e, t) {
                /^\w+=/.test(t) ? function () {
                    t = t.split('='),
                        o.search[t[0]] = t[1]
                }() : o.path.push(t)
            }), o) : o
        },
        n.prototype.data = function (t, o, n) {
            if (t = t || 'layui', n = n || localStorage, e.JSON && e.JSON.parse) {
                if (null === o) return delete n[t];
                o = 'object' == typeof o ? o : {
                    key: o
                };
                try {
                    var r = JSON.parse(n[t])
                } catch (i) {
                    var r = {}
                }
                return 'value' in o && (r[o.key] = o.value),
                o.remove && delete r[o.key],
                    n[t] = JSON.stringify(r),
                    o.key ? r[o.key] : r
            }
        },
        n.prototype.sessionData = function (e, t) {
            return this.data(e, t, sessionStorage)
        },
        n.prototype.device = function (t) {
            var o = navigator.userAgent.toLowerCase(),
                n = function (e) {
                    var t = new RegExp(e + '/([^\\s\\_\\-]+)');
                    return e = (o.match(t) || []) [1],
                    e || !1
                },
                r = {
                    os: function () {
                        return /windows/.test(o) ? 'windows' : /linux/.test(o) ? 'linux' : /iphone|ipod|ipad|ios/.test(o) ? 'ios' : /mac/.test(o) ? 'mac' : void 0
                    }(),
                    ie: function () {
                        return !!(e.ActiveXObject || 'ActiveXObject' in e) && ((o.match(/msie\s(\d+)/) || []) [1] || '11')
                    }(),
                    weixin: n('micromessenger')
                };
            return t && !r[t] && (r[t] = n(t)),
                r.android = /android/.test(o),
                r.ios = 'ios' === r.os,
                r
        },
        n.prototype.hint = function () {
            return {
                error: i
            }
        },
        n.prototype.each = function (e, t) {
            var o,
                n = this;
            if ('function' != typeof t) return n;
            if (e = e || [], e.constructor === Object) {
                for (o in e) if (t.call(e[o], o, e[o])) break
            } else for (o = 0; o < e.length && !t.call(e[o], o, e[o]); o++) ;
            return n
        },
        n.prototype.sort = function (e, t, o) {
            var n = JSON.parse(JSON.stringify(e || []));
            return t ? (n.sort(function (e, o) {
                var n = /^-?\d+$/,
                    r = e[t],
                    i = o[t];
                return n.test(r) && (r = parseFloat(r)),
                n.test(i) && (i = parseFloat(i)),
                    r && !i ? 1 : !r && i ? -1 : r > i ? 1 : r < i ? -1 : 0
            }), o && n.reverse(), n) : n
        },
        n.prototype.stope = function (t) {
            t = t || e.event;
            try {
                t.stopPropagation()
            } catch (o) {
                t.cancelBubble = !0
            }
        },
        n.prototype.onevent = function (e, t, o) {
            return 'string' != typeof e || 'function' != typeof o ? this : n.event(e, t, null, o)
        },
        n.prototype.event = n.event = function (e, t, n, r) {
            var i = this,
                a = null,
                u = t.match(/\((.*)\)$/) || [],
                l = (e + '.' + t).replace(u[0], ''),
                s = u[1] || '',
                c = function (e, t) {
                    var o = t && t.call(i, n);
                    o === !1 && null === a && (a = !1)
                };
            return r ? (o.event[l] = o.event[l] || {}, o.event[l][s] = [
                r
            ], this) : (layui.each(o.event[l], function (e, t) {
                return '{*}' === s ? void layui.each(t, c) : ('' === e && layui.each(t, c), void (s && e === s && layui.each(t, c)))
            }), a)
        },
        e.layui = new n
}(window);
layui.define(function (a) {
    var i = layui.cache;
    layui.config({
        dir: i.dir.replace(/lay\/dest\/$/, '')
    }),
        a('layui.all', layui.v)
});
layui.define(function (e) {
    'use strict';
    var r = {
            open: '{{',
            close: '}}'
        },
        c = {
            exp: function (e) {
                return new RegExp(e, 'g')
            },
            query: function (e, c, t) {
                var o = [
                    '#([\\s\\S])+?',
                    '([^{#}])*?'
                ][e || 0];
                return n((c || '') + r.open + o + r.close + (t || ''))
            },
            escape: function (e) {
                return String(e || '').replace(/&(?!#?[a-zA-Z0-9]+;)/g, '&amp;').replace(/</g, '&lt;').replace(/>/g, '&gt;').replace(/'/g, '&#39;').replace(/"/g, '&quot;')
            },
            error: function (e, r) {
                var c = 'Laytpl Error：';
                return 'object' == typeof console && console.error(c + e + '\n' + (r || '')),
                c + e
            }
        },
        n = c.exp,
        t = function (e) {
            this.tpl = e
        };
    t.pt = t.prototype,
        window.errors = 0,
        t.pt.parse = function (e, t) {
            var o = this,
                p = e,
                a = n('^' + r.open + '#', ''),
                l = n(r.close + '$', '');
            e = e.replace(/\s+|\r|\t|\n/g, ' ').replace(n(r.open + '#'), r.open + '# ').replace(n(r.close + '}'), '} ' + r.close).replace(/\\/g, '\\\\').replace(n(r.open + '!(.+?)!' + r.close), function (e) {
                return e = e.replace(n('^' + r.open + '!'), '').replace(n('!' + r.close), '').replace(n(r.open + '|' + r.close), function (e) {
                    return e.replace(/(.)/g, '\\$1')
                })
            }).replace(/(?="|')/g, '\\').replace(c.query(), function (e) {
                return e = e.replace(a, '').replace(l, ''),
                '";' + e.replace(/\\/g, '') + ';view+="'
            }).replace(c.query(1), function (e) {
                var c = '"+(';
                return e.replace(/\s/g, '') === r.open + r.close ? '' : (e = e.replace(n(r.open + '|' + r.close), ''), /^=/.test(e) && (e = e.replace(/^=/, ''), c = '"+_escape_('), c + e.replace(/\\/g, '') + ')+"')
            }),
                e = '"use strict";var view = "' + e + '";return view;';
            try {
                return o.cache = e = new Function('d, _escape_', e),
                    e(t, c.escape)
            } catch (u) {
                return delete o.cache,
                    c.error(u, p)
            }
        },
        t.pt.render = function (e, r) {
            var n,
                t = this;
            return e ? (n = t.cache ? t.cache(e, c.escape) : t.parse(t.tpl, e), r ? void r(n) : n) : c.error('no data')
        };
    var o = function (e) {
        return 'string' != typeof e ? c.error('Template not found') : new t(e)
    };
    o.config = function (e) {
        e = e || {};
        for (var c in e) r[c] = e[c]
    },
        o.v = '1.2.0',
        e('laytpl', o)
});
layui.define(function (e) {
    'use strict';
    var a = document,
        t = 'getElementById',
        n = 'getElementsByTagName',
        i = 'laypage',
        r = 'layui-disabled',
        u = function (e) {
            var a = this;
            a.config = e || {},
                a.config.index = ++s.index,
                a.render(!0)
        };
    u.prototype.type = function () {
        var e = this.config;
        if ('object' == typeof e.elem) return void 0 === e.elem.length ? 2 : 3
    },
        u.prototype.view = function () {
            var e = this,
                a = e.config,
                t = a.groups = 'groups' in a ? 0 | a.groups : 5;
            a.layout = 'object' == typeof a.layout ? a.layout : [
                'prev',
                'page',
                'next'
            ],
                a.count = 0 | a.count,
                a.curr = 0 | a.curr || 1,
                a.limits = 'object' == typeof a.limits ? a.limits : [
                    10,
                    20,
                    30,
                    40,
                    50
                ],
                a.limit = 0 | a.limit || 10,
                a.pages = Math.ceil(a.count / a.limit) || 1,
            a.curr > a.pages && (a.curr = a.pages),
                t < 0 ? t = 1 : t > a.pages && (t = a.pages),
                a.prev = 'prev' in a ? a.prev : '&#x4E0A;&#x4E00;&#x9875;',
                a.next = 'next' in a ? a.next : '&#x4E0B;&#x4E00;&#x9875;';
            var n = a.pages > t ? Math.ceil((a.curr + (t > 1 ? 1 : 0)) / (t > 0 ? t : 1)) : 1,
                i = {
                    prev: function () {
                        return a.prev ? '<a href="javascript:;" class="layui-laypage-prev' + (1 == a.curr ? ' ' + r : '') + '" data-page="' + (a.curr - 1) + '">' + a.prev + '</a>' : ''
                    }(),
                    page: function () {
                        var e = [];
                        if (a.count < 1) return '';
                        n > 1 && a.first !== !1 && 0 !== t && e.push('<a href="javascript:;" class="layui-laypage-first" data-page="1"  title="&#x9996;&#x9875;">' + (a.first || 1) + '</a>');
                        var i = Math.floor((t - 1) / 2),
                            r = n > 1 ? a.curr - i : 1,
                            u = n > 1 ? function () {
                                var e = a.curr + (t - i - 1);
                                return e > a.pages ? a.pages : e
                            }() : t;
                        for (u - r < t - 1 && (r = u - t + 1), a.first !== !1 && r > 2 && e.push('<span class="layui-laypage-spr">&#x2026;</span>'); r <= u; r++) r === a.curr ? e.push('<span class="layui-laypage-curr"><em class="layui-laypage-em" ' + (/^#/.test(a.theme) ? 'style="background-color:' + a.theme + ';"' : '') + '></em><em>' + r + '</em></span>') : e.push('<a href="javascript:;" data-page="' + r + '">' + r + '</a>');
                        return a.pages > t && a.pages > u && a.last !== !1 && (u + 1 < a.pages && e.push('<span class="layui-laypage-spr">&#x2026;</span>'), 0 !== t && e.push('<a href="javascript:;" class="layui-laypage-last" title="&#x5C3E;&#x9875;"  data-page="' + a.pages + '">' + (a.last || a.pages) + '</a>')),
                            e.join('')
                    }(),
                    next: function () {
                        return a.next ? '<a href="javascript:;" class="layui-laypage-next' + (a.curr == a.pages ? ' ' + r : '') + '" data-page="' + (a.curr + 1) + '">' + a.next + '</a>' : ''
                    }(),
                    count: '<span class="layui-laypage-count">共 ' + a.count + ' 条</span>',
                    limit: function () {
                        var e = [
                            '<span class="layui-laypage-limits"><select lay-ignore>'
                        ];
                        return layui.each(a.limits, function (t, n) {
                            e.push('<option value="' + n + '"' + (n === a.limit ? 'selected' : '') + '>' + n + ' 条/页</option>')
                        }),
                        e.join('') + '</select></span>'
                    }(),
                    refresh: [
                        '<a href="javascript:;" data-page="' + a.curr + '" class="layui-laypage-refresh">',
                        '<i class="layui-icon layui-icon-refresh"></i>',
                        '</a>'
                    ].join(''),
                    skip: function () {
                        return ['<span class="layui-laypage-skip">&#x5230;&#x7B2C;',
                            '<input type="text" min="1" value="' + a.curr + '" class="layui-input">',
                            '&#x9875;<button type="button" class="layui-laypage-btn">&#x786e;&#x5b9a;</button>',
                            '</span>'].join('')
                    }()
                };
            return ['<div class="layui-box layui-laypage layui-laypage-' + (a.theme ? /^#/.test(a.theme) ? 'molv' : a.theme : 'default') + '" id="layui-laypage-' + a.index + '">',
                function () {
                    var e = [];
                    return layui.each(a.layout, function (a, t) {
                        i[t] && e.push(i[t])
                    }),
                        e.join('')
                }(),
                '</div>'].join('')
        },
        u.prototype.jump = function (e, a) {
            if (e) {
                var t = this,
                    i = t.config,
                    r = e.children,
                    u = e[n]('button') [0],
                    l = e[n]('input') [0],
                    p = e[n]('select') [0],
                    c = function () {
                        var e = 0 | l.value.replace(/\s|\D/g, '');
                        e && (i.curr = e, t.render())
                    };
                if (a) return c();
                for (var o = 0, y = r.length; o < y; o++) 'a' === r[o].nodeName.toLowerCase() && s.on(r[o], 'click', function () {
                    var e = 0 | this.getAttribute('data-page');
                    e < 1 || e > i.pages || (i.curr = e, t.render())
                });
                p && s.on(p, 'change', function () {
                    var e = this.value;
                    i.curr * e > i.count && (i.curr = Math.ceil(i.count / e)),
                        i.limit = e,
                        t.render()
                }),
                u && s.on(u, 'click', function () {
                    c()
                })
            }
        },
        u.prototype.skip = function (e) {
            if (e) {
                var a = this,
                    t = e[n]('input') [0];
                t && s.on(t, 'keyup', function (t) {
                    var n = this.value,
                        i = t.keyCode;
                    /^(37|38|39|40)$/.test(i) || (/\D/.test(n) && (this.value = n.replace(/\D/, '')), 13 === i && a.jump(e, !0))
                })
            }
        },
        u.prototype.render = function (e) {
            var n = this,
                i = n.config,
                r = n.type(),
                u = n.view();
            2 === r ? i.elem && (i.elem.innerHTML = u) : 3 === r ? i.elem.html(u) : a[t](i.elem) && (a[t](i.elem).innerHTML = u),
            i.jump && i.jump(i, e);
            var s = a[t]('layui-laypage-' + i.index);
            n.jump(s),
            i.hash && !e && (location.hash = '!' + i.hash + '=' + i.curr),
                n.skip(s)
        };
    var s = {
        render: function (e) {
            var a = new u(e);
            return a.index
        },
        index: layui.laypage ? layui.laypage.index + 10000 : 0,
        on: function (e, a, t) {
            return e.attachEvent ? e.attachEvent('on' + a, function (a) {
                a.target = a.srcElement,
                    t.call(e, a)
            }) : e.addEventListener(a, t, !1),
                this
        }
    };
    e(i, s)
});
!function () {
    'use strict';
    var e = window.layui && layui.define,
        t = {
            getPath: function () {
                var e = document.currentScript ? document.currentScript.src : function () {
                    for (var e, t = document.scripts, n = t.length - 1, a = n; a > 0; a--) if ('interactive' === t[a].readyState) {
                        e = t[a].src;
                        break
                    }
                    return e || t[n].src
                }();
                return e.substring(0, e.lastIndexOf('/') + 1)
            }(),
            getStyle: function (e, t) {
                var n = e.currentStyle ? e.currentStyle : window.getComputedStyle(e, null);
                return n[n.getPropertyValue ? 'getPropertyValue' : 'getAttribute'](t)
            },
            link: function (e, a, i) {
                if (n.path) {
                    var r = document.getElementsByTagName('head') [0],
                        o = document.createElement('link');
                    'string' == typeof a && (i = a);
                    var s = (i || e).replace(/\.|\//g, ''),
                        l = 'layuicss-' + s,
                        d = 0;
                    o.rel = 'stylesheet',
                        o.href = n.path + e,
                        o.id = l,
                    document.getElementById(l) || r.appendChild(o),
                    'function' == typeof a && !function c() {
                        return ++d > 80 ? window.console && console.error('laydate.css: Invalid') : void (1989 === parseInt(t.getStyle(document.getElementById(l), 'width')) ? a() : setTimeout(c, 100))
                    }()
                }
            }
        },
        n = {
            v: '5.0.9',
            config: {},
            index: window.laydate && window.laydate.v ? 100000 : 0,
            path: t.getPath,
            set: function (e) {
                var t = this;
                return t.config = w.extend({}, t.config, e),
                    t
            },
            ready: function (a) {
                var i = 'laydate',
                    r = '',
                    o = (e ? 'modules/laydate/' : 'theme/') + 'default/laydate.css?v=' + n.v + r;
                return e ? layui.addcss(o, a, i) : t.link(o, a, i),
                    this
            }
        },
        a = function () {
            var e = this;
            return {
                hint: function (t) {
                    e.hint.call(e, t)
                },
                config: e.config
            }
        },
        i = 'laydate',
        r = '.layui-laydate',
        o = 'layui-this',
        s = 'laydate-disabled',
        l = '开始日期超出了结束日期<br>建议重新选择',
        d = [
            100,
            200000
        ],
        c = 'layui-laydate-static',
        m = 'layui-laydate-list',
        u = 'laydate-selected',
        h = 'layui-laydate-hint',
        y = 'laydate-day-prev',
        f = 'laydate-day-next',
        p = 'layui-laydate-footer',
        g = '.laydate-btns-confirm',
        v = 'laydate-time-text',
        D = '.laydate-btns-time',
        T = function (e) {
            var t = this;
            t.index = ++n.index,
                t.config = w.extend({}, t.config, n.config, e),
                n.ready(function () {
                    t.init()
                })
        },
        w = function (e) {
            return new C(e)
        },
        C = function (e) {
            for (var t = 0, n = 'object' == typeof e ? [
                e
            ] : (this.selector = e, document.querySelectorAll(e || null)); t < n.length; t++) this.push(n[t])
        };
    C.prototype = [],
        C.prototype.constructor = C,
        w.extend = function () {
            var e = 1,
                t = arguments,
                n = function (e, t) {
                    e = e || (t.constructor === Array ? [] : {});
                    for (var a in t) e[a] = t[a] && t[a].constructor === Object ? n(e[a], t[a]) : t[a];
                    return e
                };
            for (t[0] = 'object' == typeof t[0] ? t[0] : {}; e < t.length; e++) 'object' == typeof t[e] && n(t[0], t[e]);
            return t[0]
        },
        w.ie = function () {
            var e = navigator.userAgent.toLowerCase();
            return !!(window.ActiveXObject || 'ActiveXObject' in window) && ((e.match(/msie\s(\d+)/) || []) [1] || '11')
        }(),
        w.stope = function (e) {
            e = e || window.event,
                e.stopPropagation ? e.stopPropagation() : e.cancelBubble = !0
        },
        w.each = function (e, t) {
            var n,
                a = this;
            if ('function' != typeof t) return a;
            if (e = e || [], e.constructor === Object) {
                for (n in e) if (t.call(e[n], n, e[n])) break
            } else for (n = 0; n < e.length && !t.call(e[n], n, e[n]); n++) ;
            return a
        },
        w.digit = function (e, t, n) {
            var a = '';
            e = String(e),
                t = t || 2;
            for (var i = e.length; i < t; i++) a += '0';
            return e < Math.pow(10, t) ? a + (0 | e) : e
        },
        w.elem = function (e, t) {
            var n = document.createElement(e);
            return w.each(t || {}, function (e, t) {
                n.setAttribute(e, t)
            }),
                n
        },
        C.addStr = function (e, t) {
            return e = e.replace(/\s+/, ' '),
                t = t.replace(/\s+/, ' ').split(' '),
                w.each(t, function (t, n) {
                    new RegExp('\\b' + n + '\\b').test(e) || (e = e + ' ' + n)
                }),
                e.replace(/^\s|\s$/, '')
        },
        C.removeStr = function (e, t) {
            return e = e.replace(/\s+/, ' '),
                t = t.replace(/\s+/, ' ').split(' '),
                w.each(t, function (t, n) {
                    var a = new RegExp('\\b' + n + '\\b');
                    a.test(e) && (e = e.replace(a, ''))
                }),
                e.replace(/\s+/, ' ').replace(/^\s|\s$/, '')
        },
        C.prototype.find = function (e) {
            var t = this,
                n = 0,
                a = [],
                i = 'object' == typeof e;
            return this.each(function (r, o) {
                for (var s = i ? [
                    e
                ] : o.querySelectorAll(e || null); n < s.length; n++) a.push(s[n]);
                t.shift()
            }),
            i || (t.selector = (t.selector ? t.selector + ' ' : '') + e),
                w.each(a, function (e, n) {
                    t.push(n)
                }),
                t
        },
        C.prototype.each = function (e) {
            return w.each.call(this, this, e)
        },
        C.prototype.addClass = function (e, t) {
            return this.each(function (n, a) {
                a.className = C[t ? 'removeStr' : 'addStr'](a.className, e)
            })
        },
        C.prototype.removeClass = function (e) {
            return this.addClass(e, !0)
        },
        C.prototype.hasClass = function (e) {
            var t = !1;
            return this.each(function (n, a) {
                new RegExp('\\b' + e + '\\b').test(a.className) && (t = !0)
            }),
                t
        },
        C.prototype.attr = function (e, t) {
            var n = this;
            return void 0 === t ? function () {
                if (n.length > 0) return n[0].getAttribute(e)
            }() : n.each(function (n, a) {
                a.setAttribute(e, t)
            })
        },
        C.prototype.removeAttr = function (e) {
            return this.each(function (t, n) {
                n.removeAttribute(e)
            })
        },
        C.prototype.html = function (e) {
            return this.each(function (t, n) {
                n.innerHTML = e
            })
        },
        C.prototype.val = function (e) {
            return this.each(function (t, n) {
                n.value = e
            })
        },
        C.prototype.append = function (e) {
            return this.each(function (t, n) {
                'object' == typeof e ? n.appendChild(e) : n.innerHTML = n.innerHTML + e
            })
        },
        C.prototype.remove = function (e) {
            return this.each(function (t, n) {
                e ? n.removeChild(e) : n.parentNode.removeChild(n)
            })
        },
        C.prototype.on = function (e, t) {
            return this.each(function (n, a) {
                a.attachEvent ? a.attachEvent('on' + e, function (e) {
                    e.target = e.srcElement,
                        t.call(a, e)
                }) : a.addEventListener(e, t, !1)
            })
        },
        C.prototype.off = function (e, t) {
            return this.each(function (n, a) {
                a.detachEvent ? a.detachEvent('on' + e, t) : a.removeEventListener(e, t, !1)
            })
        },
        T.isLeapYear = function (e) {
            return e % 4 === 0 && e % 100 !== 0 || e % 400 === 0
        },
        T.prototype.config = {
            type: 'date',
            range: !1,
            format: 'yyyy-MM-dd',
            value: null,
            isInitValue: !0,
            min: '1900-1-1',
            max: '2099-12-31',
            trigger: 'focus',
            show: !1,
            showBottom: !0,
            btns: [
                'clear',
                'now',
                'confirm'
            ],
            lang: 'cn',
            theme: 'default',
            position: null,
            calendar: !1,
            mark: {},
            zIndex: null,
            done: null,
            change: null
        },
        T.prototype.lang = function () {
            var e = this,
                t = e.config,
                n = {
                    cn: {
                        weeks: [
                            '日',
                            '一',
                            '二',
                            '三',
                            '四',
                            '五',
                            '六'
                        ],
                        time: [
                            '时',
                            '分',
                            '秒'
                        ],
                        timeTips: '选择时间',
                        startTime: '开始时间',
                        endTime: '结束时间',
                        dateTips: '返回日期',
                        month: [
                            '一',
                            '二',
                            '三',
                            '四',
                            '五',
                            '六',
                            '七',
                            '八',
                            '九',
                            '十',
                            '十一',
                            '十二'
                        ],
                        tools: {
                            confirm: '确定',
                            clear: '清空',
                            now: '现在'
                        }
                    },
                    en: {
                        weeks: [
                            'Su',
                            'Mo',
                            'Tu',
                            'We',
                            'Th',
                            'Fr',
                            'Sa'
                        ],
                        time: [
                            'Hours',
                            'Minutes',
                            'Seconds'
                        ],
                        timeTips: 'Select Time',
                        startTime: 'Start Time',
                        endTime: 'End Time',
                        dateTips: 'Select Date',
                        month: [
                            'Jan',
                            'Feb',
                            'Mar',
                            'Apr',
                            'May',
                            'Jun',
                            'Jul',
                            'Aug',
                            'Sep',
                            'Oct',
                            'Nov',
                            'Dec'
                        ],
                        tools: {
                            confirm: 'Confirm',
                            clear: 'Clear',
                            now: 'Now'
                        }
                    }
                };
            return n[t.lang] || n.cn
        },
        T.prototype.init = function () {
            var e = this,
                t = e.config,
                n = 'yyyy|y|MM|M|dd|d|HH|H|mm|m|ss|s',
                a = 'static' === t.position,
                i = {
                    year: 'yyyy',
                    month: 'yyyy-MM',
                    date: 'yyyy-MM-dd',
                    time: 'HH:mm:ss',
                    datetime: 'yyyy-MM-dd HH:mm:ss'
                };
            t.elem = w(t.elem),
                t.eventElem = w(t.eventElem),
            t.elem[0] && (t.range === !0 && (t.range = '-'), t.format === i.date && (t.format = i[t.type]), e.format = t.format.match(new RegExp(n + '|.', 'g')) || [], e.EXP_IF = '', e.EXP_SPLIT = '', w.each(e.format, function (t, a) {
                var i = new RegExp(n).test(a) ? '\\d{' + function () {
                    return new RegExp(n).test(e.format[0 === t ? t + 1 : t - 1] || '') ? /^yyyy|y$/.test(a) ? 4 : a.length : /^yyyy$/.test(a) ? '1,4' : /^y$/.test(a) ? '1,308' : '1,2'
                }() + '}' : '\\' + a;
                e.EXP_IF = e.EXP_IF + i,
                    e.EXP_SPLIT = e.EXP_SPLIT + '(' + i + ')'
            }), e.EXP_IF = new RegExp('^' + (t.range ? e.EXP_IF + '\\s\\' + t.range + '\\s' + e.EXP_IF : e.EXP_IF) + '$'), e.EXP_SPLIT = new RegExp('^' + e.EXP_SPLIT + '$', ''), e.isInput(t.elem[0]) || 'focus' === t.trigger && (t.trigger = 'click'), t.elem.attr('lay-key') || (t.elem.attr('lay-key', e.index), t.eventElem.attr('lay-key', e.index)), t.mark = w.extend({}, t.calendar && 'cn' === t.lang ? {
                    '0-1-1': '元旦',
                    '0-2-14': '情人',
                    '0-3-8': '妇女',
                    '0-3-12': '植树',
                    '0-4-1': '愚人',
                    '0-5-1': '劳动',
                    '0-5-4': '青年',
                    '0-6-1': '儿童',
                    '0-9-10': '教师',
                    '0-9-18': '国耻',
                    '0-10-1': '国庆',
                    '0-12-25': '圣诞'
                }
                : {}, t.mark), w.each(['min',
                'max'], function (e, n) {
                var a = [],
                    i = [];
                if ('number' == typeof t[n]) {
                    var r = t[n],
                        o = (new Date).getTime(),
                        s = 86400000,
                        l = new Date(r ? r < s ? o + r * s : r : o);
                    a = [
                        l.getFullYear(),
                        l.getMonth() + 1,
                        l.getDate()
                    ],
                    r < s || (i = [
                        l.getHours(),
                        l.getMinutes(),
                        l.getSeconds()
                    ])
                } else a = (t[n].match(/\d+-\d+-\d+/) || [
                    ''
                ]) [0].split('-'),
                    i = (t[n].match(/\d+:\d+:\d+/) || [
                        ''
                    ]) [0].split(':');
                t[n] = {
                    year: 0 | a[0] || (new Date).getFullYear(),
                    month: a[1] ? (0 | a[1]) - 1 : (new Date).getMonth(),
                    date: 0 | a[2] || (new Date).getDate(),
                    hours: 0 | i[0],
                    minutes: 0 | i[1],
                    seconds: 0 | i[2]
                }
            }), e.elemID = 'layui-laydate' + t.elem.attr('lay-key'), (t.show || a) && e.render(), a || e.events(), t.value && t.isInitValue && (t.value.constructor === Date ? e.setValue(e.parse(0, e.systemDate(t.value))) : e.setValue(t.value)))
        },
        T.prototype.render = function () {
            var e = this,
                t = e.config,
                n = e.lang(),
                a = 'static' === t.position,
                i = e.elem = w.elem('div', {
                    id: e.elemID,
                    'class': [
                        'layui-laydate',
                        t.range ? ' layui-laydate-range' : '',
                        a ? ' ' + c : '',
                        t.theme && 'default' !== t.theme && !/^#/.test(t.theme) ? ' laydate-theme-' + t.theme : ''
                    ].join('')
                }),
                r = e.elemMain = [],
                o = e.elemHeader = [],
                s = e.elemCont = [],
                l = e.table = [],
                d = e.footer = w.elem('div', {
                    'class': p
                });
            if (t.zIndex && (i.style.zIndex = t.zIndex), w.each(new Array(2), function (e) {
                if (!t.range && e > 0) return !0;
                var a = w.elem('div', {
                        'class': 'layui-laydate-header'
                    }),
                    i = [
                        function () {
                            var e = w.elem('i', {
                                'class': 'layui-icon laydate-icon laydate-prev-y'
                            });
                            return e.innerHTML = '&#xe65a;',
                                e
                        }(),
                        function () {
                            var e = w.elem('i', {
                                'class': 'layui-icon laydate-icon laydate-prev-m'
                            });
                            return e.innerHTML = '&#xe603;',
                                e
                        }(),
                        function () {
                            var e = w.elem('div', {
                                    'class': 'laydate-set-ym'
                                }),
                                t = w.elem('span'),
                                n = w.elem('span');
                            return e.appendChild(t),
                                e.appendChild(n),
                                e
                        }(),
                        function () {
                            var e = w.elem('i', {
                                'class': 'layui-icon laydate-icon laydate-next-m'
                            });
                            return e.innerHTML = '&#xe602;',
                                e
                        }(),
                        function () {
                            var e = w.elem('i', {
                                'class': 'layui-icon laydate-icon laydate-next-y'
                            });
                            return e.innerHTML = '&#xe65b;',
                                e
                        }()
                    ],
                    d = w.elem('div', {
                        'class': 'layui-laydate-content'
                    }),
                    c = w.elem('table'),
                    m = w.elem('thead'),
                    u = w.elem('tr');
                w.each(i, function (e, t) {
                    a.appendChild(t)
                }),
                    m.appendChild(u),
                    w.each(new Array(6), function (e) {
                        var t = c.insertRow(0);
                        w.each(new Array(7), function (a) {
                            if (0 === e) {
                                var i = w.elem('th');
                                i.innerHTML = n.weeks[a],
                                    u.appendChild(i)
                            }
                            t.insertCell(a)
                        })
                    }),
                    c.insertBefore(m, c.children[0]),
                    d.appendChild(c),
                    r[e] = w.elem('div', {
                        'class': 'layui-laydate-main laydate-main-list-' + e
                    }),
                    r[e].appendChild(a),
                    r[e].appendChild(d),
                    o.push(i),
                    s.push(d),
                    l.push(c)
            }), w(d).html(function () {
                var e = [],
                    i = [];
                return 'datetime' === t.type && e.push('<span lay-type="datetime" class="laydate-btns-time">' + n.timeTips + '</span>'),
                    w.each(t.btns, function (e, r) {
                        var o = n.tools[r] || 'btn';
                        t.range && 'now' === r || (a && 'clear' === r && (o = 'cn' === t.lang ? '重置' : 'Reset'), i.push('<span lay-type="' + r + '" class="laydate-btns-' + r + '">' + o + '</span>'))
                    }),
                    e.push('<div class="laydate-footer-btns">' + i.join('') + '</div>'),
                    e.join('')
            }()), w.each(r, function (e, t) {
                i.appendChild(t)
            }), t.showBottom && i.appendChild(d), /^#/.test(t.theme)) {
                var m = w.elem('style'),
                    u = [
                        '#{{id}} .layui-laydate-header{background-color:{{theme}};}',
                        '#{{id}} .layui-this{background-color:{{theme}} !important;}'
                    ].join('').replace(/{{id}}/g, e.elemID).replace(/{{theme}}/g, t.theme);
                'styleSheet' in m ? (m.setAttribute('type', 'text/css'), m.styleSheet.cssText = u) : m.innerHTML = u,
                    w(i).addClass('laydate-theme-molv'),
                    i.appendChild(m)
            }
            e.remove(T.thisElemDate),
                a ? t.elem.append(i) : (document.body.appendChild(i), e.position()),
                e.checkDate().calendar(),
                e.changeEvent(),
                T.thisElemDate = e.elemID,
            'function' == typeof t.ready && t.ready(w.extend({}, t.dateTime, {
                month: t.dateTime.month + 1
            }))
        },
        T.prototype.remove = function (e) {
            var t = this,
                n = (t.config, w('#' + (e || t.elemID)));
            return n.hasClass(c) || t.checkDate(function () {
                n.remove()
            }),
                t
        },
        T.prototype.position = function () {
            var e = this,
                t = e.config,
                n = e.bindElem || t.elem[0],
                a = n.getBoundingClientRect(),
                i = e.elem.offsetWidth,
                r = e.elem.offsetHeight,
                o = function (e) {
                    return e = e ? 'scrollLeft' : 'scrollTop',
                    document.body[e] | document.documentElement[e]
                },
                s = function (e) {
                    return document.documentElement[e ? 'clientWidth' : 'clientHeight']
                },
                l = 5,
                d = a.left,
                c = a.bottom;
            d + i + l > s('width') && (d = s('width') - i - l),
            c + r + l > s() && (c = a.top > r ? a.top - r : s() - r, c -= 2 * l),
            t.position && (e.elem.style.position = t.position),
                e.elem.style.left = d + ('fixed' === t.position ? 0 : o(1)) + 'px',
                e.elem.style.top = c + ('fixed' === t.position ? 0 : o()) + 'px'
        },
        T.prototype.hint = function (e) {
            var t = this,
                n = (t.config, w.elem('div', {
                    'class': h
                }));
            t.elem && (n.innerHTML = e || '', w(t.elem).find('.' + h).remove(), t.elem.appendChild(n), clearTimeout(t.hinTimer), t.hinTimer = setTimeout(function () {
                w(t.elem).find('.' + h).remove()
            }, 3000))
        },
        T.prototype.getAsYM = function (e, t, n) {
            return n ? t-- : t++,
            t < 0 && (t = 11, e--),
            t > 11 && (t = 0, e++),
                [
                    e,
                    t
                ]
        },
        T.prototype.systemDate = function (e) {
            var t = e || new Date;
            return {
                year: t.getFullYear(),
                month: t.getMonth(),
                date: t.getDate(),
                hours: e ? e.getHours() : 0,
                minutes: e ? e.getMinutes() : 0,
                seconds: e ? e.getSeconds() : 0
            }
        },
        T.prototype.checkDate = function (e) {
            var t,
                a,
                i = this,
                r = (new Date, i.config),
                o = r.dateTime = r.dateTime || i.systemDate(),
                s = i.bindElem || r.elem[0],
                l = (i.isInput(s) ? 'val' : 'html', i.isInput(s) ? s.value : 'static' === r.position ? '' : s.innerHTML),
                c = function (e) {
                    e.year > d[1] && (e.year = d[1], a = !0),
                    e.month > 11 && (e.month = 11, a = !0),
                    e.hours > 23 && (e.hours = 0, a = !0),
                    e.minutes > 59 && (e.minutes = 0, e.hours++, a = !0),
                    e.seconds > 59 && (e.seconds = 0, e.minutes++, a = !0),
                        t = n.getEndDate(e.month + 1, e.year),
                    e.date > t && (e.date = t, a = !0)
                },
                m = function (e, t, n) {
                    var o = [
                        'startTime',
                        'endTime'
                    ];
                    t = (t.match(i.EXP_SPLIT) || []).slice(1),
                        n = n || 0,
                    r.range && (i[o[n]] = i[o[n]] || {}),
                        w.each(i.format, function (s, l) {
                            var c = parseFloat(t[s]);
                            t[s].length < l.length && (a = !0),
                                /yyyy|y/.test(l) ? (c < d[0] && (c = d[0], a = !0), e.year = c) : /MM|M/.test(l) ? (c < 1 && (c = 1, a = !0), e.month = c - 1) : /dd|d/.test(l) ? (c < 1 && (c = 1, a = !0), e.date = c) : /HH|H/.test(l) ? (c < 1 && (c = 0, a = !0), e.hours = c, r.range && (i[o[n]].hours = c)) : /mm|m/.test(l) ? (c < 1 && (c = 0, a = !0), e.minutes = c, r.range && (i[o[n]].minutes = c)) : /ss|s/.test(l) && (c < 1 && (c = 0, a = !0), e.seconds = c, r.range && (i[o[n]].seconds = c))
                        }),
                        c(e)
                };
            return 'limit' === e ? (c(o), i) : (l = l || r.value, 'string' == typeof l && (l = l.replace(/\s+/g, ' ').replace(/^\s|\s$/g, '')), i.startState && !i.endState && (delete i.startState, i.endState = !0), 'string' == typeof l && l ? i.EXP_IF.test(l) ? r.range ? (l = l.split(' ' + r.range + ' '), i.startDate = i.startDate || i.systemDate(), i.endDate = i.endDate || i.systemDate(), r.dateTime = w.extend({}, i.startDate), w.each([i.startDate,
                i.endDate], function (e, t) {
                m(t, l[e], e)
            })) : m(o, l) : (i.hint('日期格式不合法<br>必须遵循下述格式：<br>' + (r.range ? r.format + ' ' + r.range + ' ' + r.format : r.format) + '<br>已为你重置'), a = !0) : l && l.constructor === Date ? r.dateTime = i.systemDate(l) : (r.dateTime = i.systemDate(), delete i.startState, delete i.endState, delete i.startDate, delete i.endDate, delete i.startTime, delete i.endTime), c(o), a && l && i.setValue(r.range ? i.endDate ? i.parse() : '' : i.parse()), e && e(), i)
        },
        T.prototype.mark = function (e, t) {
            var n,
                a = this,
                i = a.config;
            return w.each(i.mark, function (e, a) {
                var i = e.split('-');
                i[0] != t[0] && 0 != i[0] || i[1] != t[1] && 0 != i[1] || i[2] != t[2] || (n = a || t[2])
            }),
            n && e.html('<span class="laydate-day-mark">' + n + '</span>'),
                a
        },
        T.prototype.limit = function (e, t, n, a) {
            var i,
                r = this,
                o = r.config,
                l = {},
                d = o[n > 41 ? 'endDate' : 'dateTime'],
                c = w.extend({}, d, t || {});
            return w.each({
                now: c,
                min: o.min,
                max: o.max
            }, function (e, t) {
                l[e] = r.newDate(w.extend({
                    year: t.year,
                    month: t.month,
                    date: t.date
                }, function () {
                    var e = {};
                    return w.each(a, function (n, a) {
                        e[a] = t[a]
                    }),
                        e
                }())).getTime()
            }),
                i = l.now < l.min || l.now > l.max,
            e && e[i ? 'addClass' : 'removeClass'](s),
                i
        },
        T.prototype.calendar = function (e) {
            var t,
                a,
                i,
                r = this,
                s = r.config,
                l = e || s.dateTime,
                c = new Date,
                m = r.lang(),
                u = 'date' !== s.type && 'datetime' !== s.type,
                h = e ? 1 : 0,
                y = w(r.table[h]).find('td'),
                f = w(r.elemHeader[h][2]).find('span');
            if (l.year < d[0] && (l.year = d[0], r.hint('最低只能支持到公元' + d[0] + '年')), l.year > d[1] && (l.year = d[1], r.hint('最高只能支持到公元' + d[1] + '年')), r.firstDate || (r.firstDate = w.extend({}, l)), c.setFullYear(l.year, l.month, 1), t = c.getDay(), a = n.getEndDate(l.month || 12, l.year), i = n.getEndDate(l.month + 1, l.year), w.each(y, function (e, n) {
                var d = [
                        l.year,
                        l.month
                    ],
                    c = 0;
                n = w(n),
                    n.removeAttr('class'),
                    e < t ? (c = a - t + e, n.addClass('laydate-day-prev'), d = r.getAsYM(l.year, l.month, 'sub')) : e >= t && e < i + t ? (c = e - t, s.range || c + 1 === l.date && n.addClass(o)) : (c = e - i - t, n.addClass('laydate-day-next'), d = r.getAsYM(l.year, l.month)),
                    d[1]++,
                    d[2] = c + 1,
                    n.attr('lay-ymd', d.join('-')).html(d[2]),
                    r.mark(n, d).limit(n, {
                        year: d[0],
                        month: d[1] - 1,
                        date: d[2]
                    }, e)
            }), w(f[0]).attr('lay-ym', l.year + '-' + (l.month + 1)), w(f[1]).attr('lay-ym', l.year + '-' + (l.month + 1)), 'cn' === s.lang ? (w(f[0]).attr('lay-type', 'year').html(l.year + '年'), w(f[1]).attr('lay-type', 'month').html(l.month + 1 + '月')) : (w(f[0]).attr('lay-type', 'month').html(m.month[l.month]), w(f[1]).attr('lay-type', 'year').html(l.year)), u && (s.range && (e ? r.endDate = r.endDate || {
                    year: l.year + ('year' === s.type ? 1 : 0),
                    month: l.month + ('month' === s.type ? 0 : -1)
                }
                : r.startDate = r.startDate || {
                    year: l.year,
                    month: l.month
                }, e && (r.listYM = [
                [r.startDate.year,
                    r.startDate.month + 1],
                [
                    r.endDate.year,
                    r.endDate.month + 1
                ]
            ], r.list(s.type, 0).list(s.type, 1), 'time' === s.type ? r.setBtnStatus('时间', w.extend({}, r.systemDate(), r.startTime), w.extend({}, r.systemDate(), r.endTime)) : r.setBtnStatus(!0))), s.range || (r.listYM = [
                [l.year,
                    l.month + 1]
            ], r.list(s.type, 0))), s.range && !e) {
                var p = r.getAsYM(l.year, l.month);
                r.calendar(w.extend({}, l, {
                    year: p[0],
                    month: p[1]
                }))
            }
            return s.range || r.limit(w(r.footer).find(g), null, 0, [
                'hours',
                'minutes',
                'seconds'
            ]),
            s.range && e && !u && r.stampRange(),
                r
        },
        T.prototype.list = function (e, t) {
            var n = this,
                a = n.config,
                i = a.dateTime,
                r = n.lang(),
                l = a.range && 'date' !== a.type && 'datetime' !== a.type,
                d = w.elem('ul', {
                    'class': m + ' ' + {
                        year: 'laydate-year-list',
                        month: 'laydate-month-list',
                        time: 'laydate-time-list'
                    }
                        [
                        e
                        ]
                }),
                c = n.elemHeader[t],
                u = w(c[2]).find('span'),
                h = n.elemCont[t || 0],
                y = w(h).find('.' + m) [0],
                f = 'cn' === a.lang,
                p = f ? '年' : '',
                T = n.listYM[t] || {},
                C = [
                    'hours',
                    'minutes',
                    'seconds'
                ],
                x = [
                    'startTime',
                    'endTime'
                ][t];
            if (T[0] < 1 && (T[0] = 1), 'year' === e) {
                var M,
                    b = M = T[0] - 7;
                b < 1 && (b = M = 1),
                    w.each(new Array(15), function (e) {
                        var i = w.elem('li', {
                                'lay-ym': M
                            }),
                            r = {
                                year: M
                            };
                        M == T[0] && w(i).addClass(o),
                            i.innerHTML = M + p,
                            d.appendChild(i),
                            M < n.firstDate.year ? (r.month = a.min.month, r.date = a.min.date) : M >= n.firstDate.year && (r.month = a.max.month, r.date = a.max.date),
                            n.limit(w(i), r, t),
                            M++
                    }),
                    w(u[f ? 0 : 1]).attr('lay-ym', M - 8 + '-' + T[1]).html(b + p + ' - ' + (M - 1 + p))
            } else if ('month' === e) w.each(new Array(12), function (e) {
                var i = w.elem('li', {
                        'lay-ym': e
                    }),
                    s = {
                        year: T[0],
                        month: e
                    };
                e + 1 == T[1] && w(i).addClass(o),
                    i.innerHTML = r.month[e] + (f ? '月' : ''),
                    d.appendChild(i),
                    T[0] < n.firstDate.year ? s.date = a.min.date : T[0] >= n.firstDate.year && (s.date = a.max.date),
                    n.limit(w(i), s, t)
            }),
                w(u[f ? 0 : 1]).attr('lay-ym', T[0] + '-' + T[1]).html(T[0] + p);
            else if ('time' === e) {
                var E = function () {
                    w(d).find('ol').each(function (e, a) {
                        w(a).find('li').each(function (a, i) {
                            n.limit(w(i), [
                                {
                                    hours: a
                                },
                                {
                                    hours: n[x].hours,
                                    minutes: a
                                },
                                {
                                    hours: n[x].hours,
                                    minutes: n[x].minutes,
                                    seconds: a
                                }
                            ][e], t, [
                                ['hours'],
                                [
                                    'hours',
                                    'minutes'
                                ],
                                [
                                    'hours',
                                    'minutes',
                                    'seconds'
                                ]
                            ][e])
                        })
                    }),
                    a.range || n.limit(w(n.footer).find(g), n[x], 0, [
                        'hours',
                        'minutes',
                        'seconds'
                    ])
                };
                a.range ? n[x] || (n[x] = {
                    hours: 0,
                    minutes: 0,
                    seconds: 0
                }) : n[x] = i,
                    w.each([24,
                        60,
                        60], function (e, t) {
                        var a = w.elem('li'),
                            i = [
                                '<p>' + r.time[e] + '</p><ol>'
                            ];
                        w.each(new Array(t), function (t) {
                            i.push('<li' + (n[x][C[e]] === t ? ' class="' + o + '"' : '') + '>' + w.digit(t, 2) + '</li>')
                        }),
                            a.innerHTML = i.join('') + '</ol>',
                            d.appendChild(a)
                    }),
                    E()
            }
            if (y && h.removeChild(y), h.appendChild(d), 'year' === e || 'month' === e) w(n.elemMain[t]).addClass('laydate-ym-show'),
                w(d).find('li').on('click', function () {
                    var r = 0 | w(this).attr('lay-ym');
                    if (!w(this).hasClass(s)) {
                        if (0 === t) i[e] = r,
                        l && (n.startDate[e] = r),
                            n.limit(w(n.footer).find(g), null, 0);
                        else if (l) n.endDate[e] = r;
                        else {
                            var c = 'year' === e ? n.getAsYM(r, T[1] - 1, 'sub') : n.getAsYM(T[0], r, 'sub');
                            w.extend(i, {
                                year: c[0],
                                month: c[1]
                            })
                        }
                        'year' === a.type || 'month' === a.type ? (w(d).find('.' + o).removeClass(o), w(this).addClass(o), 'month' === a.type && 'year' === e && (n.listYM[t][0] = r, l && (n[['startDate',
                            'endDate'][t]].year = r), n.list('month', t))) : (n.checkDate('limit').calendar(), n.closeList()),
                            n.setBtnStatus(),
                        a.range || n.done(null, 'change'),
                            w(n.footer).find(D).removeClass(s)
                    }
                });
            else {
                var S = w.elem('span', {
                        'class': v
                    }),
                    k = function () {
                        w(d).find('ol').each(function (e) {
                            var t = this,
                                a = w(t).find('li');
                            t.scrollTop = 30 * (n[x][C[e]] - 2),
                            t.scrollTop <= 0 && a.each(function (e, n) {
                                if (!w(this).hasClass(s)) return t.scrollTop = 30 * (e - 2),
                                    !0
                            })
                        })
                    },
                    H = w(c[2]).find('.' + v);
                k(),
                    S.innerHTML = a.range ? [
                        r.startTime,
                        r.endTime
                    ][t] : r.timeTips,
                    w(n.elemMain[t]).addClass('laydate-time-show'),
                H[0] && H.remove(),
                    c[2].appendChild(S),
                    w(d).find('ol').each(function (e) {
                        var t = this;
                        w(t).find('li').on('click', function () {
                            var r = 0 | this.innerHTML;
                            w(this).hasClass(s) || (a.range ? n[x][C[e]] = r : i[C[e]] = r, w(t).find('.' + o).removeClass(o), w(this).addClass(o), E(), k(), (n.endDate || 'time' === a.type) && n.done(null, 'change'), n.setBtnStatus())
                        })
                    })
            }
            return n
        },
        T.prototype.listYM = [],
        T.prototype.closeList = function () {
            var e = this;
            e.config;
            w.each(e.elemCont, function (t, n) {
                w(this).find('.' + m).remove(),
                    w(e.elemMain[t]).removeClass('laydate-ym-show laydate-time-show')
            }),
                w(e.elem).find('.' + v).remove()
        },
        T.prototype.setBtnStatus = function (e, t, n) {
            var a,
                i = this,
                r = i.config,
                o = w(i.footer).find(g),
                d = r.range && 'date' !== r.type && 'time' !== r.type;
            d && (t = t || i.startDate, n = n || i.endDate, a = i.newDate(t).getTime() > i.newDate(n).getTime(), i.limit(null, t) || i.limit(null, n) ? o.addClass(s) : o[a ? 'addClass' : 'removeClass'](s), e && a && i.hint('string' == typeof e ? l.replace(/日期/g, e) : l))
        },
        T.prototype.parse = function (e, t) {
            var n = this,
                a = n.config,
                i = t || (e ? w.extend({}, n.endDate, n.endTime) : a.range ? w.extend({}, n.startDate, n.startTime) : a.dateTime),
                r = n.format.concat();
            return w.each(r, function (e, t) {
                /yyyy|y/.test(t) ? r[e] = w.digit(i.year, t.length) : /MM|M/.test(t) ? r[e] = w.digit(i.month + 1, t.length) : /dd|d/.test(t) ? r[e] = w.digit(i.date, t.length) : /HH|H/.test(t) ? r[e] = w.digit(i.hours, t.length) : /mm|m/.test(t) ? r[e] = w.digit(i.minutes, t.length) : /ss|s/.test(t) && (r[e] = w.digit(i.seconds, t.length))
            }),
                a.range && !e ? r.join('') + ' ' + a.range + ' ' + n.parse(1) : r.join('')
        },
        T.prototype.newDate = function (e) {
            return e = e || {},
                new Date(e.year || 1, e.month || 0, e.date || 1, e.hours || 0, e.minutes || 0, e.seconds || 0)
        },
        T.prototype.setValue = function (e) {
            var t = this,
                n = t.config,
                a = t.bindElem || n.elem[0],
                i = t.isInput(a) ? 'val' : 'html';
            return 'static' === n.position || w(a) [i](e || ''),
                this
        },
        T.prototype.stampRange = function () {
            var e,
                t,
                n = this,
                a = n.config,
                i = w(n.elem).find('td');
            if (a.range && !n.endDate && w(n.footer).find(g).addClass(s), n.endDate) return e = n.newDate({
                year: n.startDate.year,
                month: n.startDate.month,
                date: n.startDate.date
            }).getTime(),
                t = n.newDate({
                    year: n.endDate.year,
                    month: n.endDate.month,
                    date: n.endDate.date
                }).getTime(),
                e > t ? n.hint(l) : void w.each(i, function (a, i) {
                    var r = w(i).attr('lay-ymd').split('-'),
                        s = n.newDate({
                            year: r[0],
                            month: r[1] - 1,
                            date: r[2]
                        }).getTime();
                    w(i).removeClass(u + ' ' + o),
                    s !== e && s !== t || w(i).addClass(w(i).hasClass(y) || w(i).hasClass(f) ? u : o),
                    s > e && s < t && w(i).addClass(u)
                })
        },
        T.prototype.done = function (e, t) {
            var n = this,
                a = n.config,
                i = w.extend({}, n.startDate ? w.extend(n.startDate, n.startTime) : a.dateTime),
                r = w.extend({}, w.extend(n.endDate, n.endTime));
            return w.each([i,
                r], function (e, t) {
                'month' in t && w.extend(t, {
                    month: t.month + 1
                })
            }),
                e = e || [
                    n.parse(),
                    i,
                    r
                ],
            'function' == typeof a[t || 'done'] && a[t || 'done'].apply(a, e),
                n
        },
        T.prototype.choose = function (e) {
            var t = this,
                n = t.config,
                a = n.dateTime,
                i = w(t.elem).find('td'),
                r = e.attr('lay-ymd').split('-'),
                l = function (e) {
                    new Date;
                    e && w.extend(a, r),
                    n.range && (t.startDate ? w.extend(t.startDate, r) : t.startDate = w.extend({}, r, t.startTime), t.startYMD = r)
                };
            if (r = {
                year: 0 | r[0],
                month: (0 | r[1]) - 1,
                date: 0 | r[2]
            }, !e.hasClass(s)) if (n.range) {
                if (w.each(['startTime',
                    'endTime'], function (e, n) {
                    t[n] = t[n] || {
                        hours: 0,
                        minutes: 0,
                        seconds: 0
                    }
                }), t.endState) l(),
                    delete t.endState,
                    delete t.endDate,
                    t.startState = !0,
                    i.removeClass(o + ' ' + u),
                    e.addClass(o);
                else if (t.startState) {
                    if (e.addClass(o), t.endDate ? w.extend(t.endDate, r) : t.endDate = w.extend({}, r, t.endTime), t.newDate(r).getTime() < t.newDate(t.startYMD).getTime()) {
                        var d = w.extend({}, t.endDate, {
                            hours: t.startDate.hours,
                            minutes: t.startDate.minutes,
                            seconds: t.startDate.seconds
                        });
                        w.extend(t.endDate, t.startDate, {
                            hours: t.endDate.hours,
                            minutes: t.endDate.minutes,
                            seconds: t.endDate.seconds
                        }),
                            t.startDate = d
                    }
                    n.showBottom || t.done(),
                        t.stampRange(),
                        t.endState = !0,
                        t.done(null, 'change')
                } else e.addClass(o),
                    l(),
                    t.startState = !0;
                w(t.footer).find(g) [t.endDate ? 'removeClass' : 'addClass'](s)
            } else 'static' === n.position ? (l(!0), t.calendar().done().done(null, 'change')) : 'date' === n.type ? (l(!0), t.setValue(t.parse()).remove().done()) : 'datetime' === n.type && (l(!0), t.calendar().done(null, 'change'))
        },
        T.prototype.tool = function (e, t) {
            var n = this,
                a = n.config,
                i = a.dateTime,
                r = 'static' === a.position,
                o = {
                    datetime: function () {
                        w(e).hasClass(s) || (n.list('time', 0), a.range && n.list('time', 1), w(e).attr('lay-type', 'date').html(n.lang().dateTips))
                    },
                    date: function () {
                        n.closeList(),
                            w(e).attr('lay-type', 'datetime').html(n.lang().timeTips)
                    },
                    clear: function () {
                        n.setValue('').remove(),
                        r && (w.extend(i, n.firstDate), n.calendar()),
                        a.range && (delete n.startState, delete n.endState, delete n.endDate, delete n.startTime, delete n.endTime),
                            n.done(['',
                                {},
                                {}
                            ])
                    },
                    now: function () {
                        var e = new Date;
                        w.extend(i, n.systemDate(), {
                            hours: e.getHours(),
                            minutes: e.getMinutes(),
                            seconds: e.getSeconds()
                        }),
                            n.setValue(n.parse()).remove(),
                        r && n.calendar(),
                            n.done()
                    },
                    confirm: function () {
                        if (a.range) {
                            if (!n.endDate) return n.hint('请先选择日期范围');
                            if (w(e).hasClass(s)) return n.hint('time' === a.type ? l.replace(/日期/g, '时间') : l)
                        } else if (w(e).hasClass(s)) return n.hint('不在有效日期或时间范围内');
                        n.done(),
                            n.setValue(n.parse()).remove()
                    }
                };
            o[t] && o[t]()
        },
        T.prototype.change = function (e) {
            var t = this,
                n = t.config,
                a = n.dateTime,
                i = n.range && ('year' === n.type || 'month' === n.type),
                r = t.elemCont[e || 0],
                o = t.listYM[e],
                s = function (s) {
                    var l = [
                            'startDate',
                            'endDate'
                        ][e],
                        d = w(r).find('.laydate-year-list') [0],
                        c = w(r).find('.laydate-month-list') [0];
                    return d && (o[0] = s ? o[0] - 15 : o[0] + 15, t.list('year', e)),
                    c && (s ? o[0]-- : o[0]++, t.list('month', e)),
                    (d || c) && (w.extend(a, {
                        year: o[0]
                    }), i && (t[l].year = o[0]), n.range || t.done(null, 'change'), t.setBtnStatus(), n.range || t.limit(w(t.footer).find(g), {
                        year: o[0]
                    })),
                    d || c
                };
            return {
                prevYear: function () {
                    s('sub') || (a.year--, t.checkDate('limit').calendar(), n.range || t.done(null, 'change'))
                },
                prevMonth: function () {
                    var e = t.getAsYM(a.year, a.month, 'sub');
                    w.extend(a, {
                        year: e[0],
                        month: e[1]
                    }),
                        t.checkDate('limit').calendar(),
                    n.range || t.done(null, 'change')
                },
                nextMonth: function () {
                    var e = t.getAsYM(a.year, a.month);
                    w.extend(a, {
                        year: e[0],
                        month: e[1]
                    }),
                        t.checkDate('limit').calendar(),
                    n.range || t.done(null, 'change')
                },
                nextYear: function () {
                    s() || (a.year++, t.checkDate('limit').calendar(), n.range || t.done(null, 'change'))
                }
            }
        },
        T.prototype.changeEvent = function () {
            var e = this;
            e.config;
            w(e.elem).on('click', function (e) {
                w.stope(e)
            }),
                w.each(e.elemHeader, function (t, n) {
                    w(n[0]).on('click', function (n) {
                        e.change(t).prevYear()
                    }),
                        w(n[1]).on('click', function (n) {
                            e.change(t).prevMonth()
                        }),
                        w(n[2]).find('span').on('click', function (n) {
                            var a = w(this),
                                i = a.attr('lay-ym'),
                                r = a.attr('lay-type');
                            i && (i = i.split('-'), e.listYM[t] = [
                                0 | i[0],
                                0 | i[1]
                            ], e.list(r, t), w(e.footer).find(D).addClass(s))
                        }),
                        w(n[3]).on('click', function (n) {
                            e.change(t).nextMonth()
                        }),
                        w(n[4]).on('click', function (n) {
                            e.change(t).nextYear()
                        })
                }),
                w.each(e.table, function (t, n) {
                    var a = w(n).find('td');
                    a.on('click', function () {
                        e.choose(w(this))
                    })
                }),
                w(e.footer).find('span').on('click', function () {
                    var t = w(this).attr('lay-type');
                    e.tool(this, t)
                })
        },
        T.prototype.isInput = function (e) {
            return /input|textarea/.test(e.tagName.toLocaleLowerCase())
        },
        T.prototype.events = function () {
            var e = this,
                t = e.config,
                n = function (n, a) {
                    n.on(t.trigger, function () {
                        a && (e.bindElem = this),
                            e.render()
                    })
                };
            t.elem[0] && !t.elem[0].eventHandler && (n(t.elem, 'bind'), n(t.eventElem), w(document).on('click', function (n) {
                n.target !== t.elem[0] && n.target !== t.eventElem[0] && n.target !== w(t.closeStop) [0] && e.remove()
            }).on('keydown', function (t) {
                13 === t.keyCode && w('#' + e.elemID) [0] && e.elemID === T.thisElem && (t.preventDefault(), w(e.footer).find(g) [0].click())
            }), w(window).on('resize', function () {
                return !(!e.elem || !w(r) [0]) && void e.position()
            }), t.elem[0].eventHandler = !0)
        },
        n.render = function (e) {
            var t = new T(e);
            return a.call(t)
        },
        n.getEndDate = function (e, t) {
            var n = new Date;
            return n.setFullYear(t || n.getFullYear(), e || n.getMonth() + 1, 1),
                new Date(n.getTime() - 86400000).getDate()
        },
        window.lay = window.lay || w,
        e ? (n.ready(), layui.define(function (e) {
            n.path = layui.cache.dir,
                e(i, n)
        })) : 'function' == typeof define && define.amd ? define(function () {
            return n
        }) : function () {
            n.ready(),
                window.laydate = n
        }()
}();
!function (e, t) {
    'object' == typeof module && 'object' == typeof module.exports ? module.exports = e.document ? t(e, !0) : function (e) {
            if (!e.document) throw new Error('jQuery requires a window with a document');
            return t(e)
        }
        : t(e)
}('undefined' != typeof window ? window : this, function (e, t) {
    function n(e) {
        var t = !!e && 'length' in e && e.length,
            n = pe.type(e);
        return 'function' !== n && !pe.isWindow(e) && ('array' === n || 0 === t || 'number' == typeof t && t > 0 && t - 1 in e)
    }

    function r(e, t, n) {
        if (pe.isFunction(t)) return pe.grep(e, function (e, r) {
            return !!t.call(e, r, e) !== n
        });
        if (t.nodeType) return pe.grep(e, function (e) {
            return e === t !== n
        });
        if ('string' == typeof t) {
            if (Ce.test(t)) return pe.filter(t, e, n);
            t = pe.filter(t, e)
        }
        return pe.grep(e, function (e) {
            return pe.inArray(e, t) > -1 !== n
        })
    }

    function i(e, t) {
        do e = e[t];
        while (e && 1 !== e.nodeType);
        return e
    }

    function o(e) {
        var t = {};
        return pe.each(e.match(De) || [], function (e, n) {
            t[n] = !0
        }),
            t
    }

    function a() {
        re.addEventListener ? (re.removeEventListener('DOMContentLoaded', s), e.removeEventListener('load', s)) : (re.detachEvent('onreadystatechange', s), e.detachEvent('onload', s))
    }

    function s() {
        (re.addEventListener || 'load' === e.event.type || 'complete' === re.readyState) && (a(), pe.ready())
    }

    function u(e, t, n) {
        if (void 0 === n && 1 === e.nodeType) {
            var r = 'data-' + t.replace(_e, '-$1').toLowerCase();
            if (n = e.getAttribute(r), 'string' == typeof n) {
                try {
                    n = 'true' === n || 'false' !== n && ('null' === n ? null : +n + '' === n ? +n : qe.test(n) ? pe.parseJSON(n) : n)
                } catch (i) {
                }
                pe.data(e, t, n)
            } else n = void 0
        }
        return n
    }

    function l(e) {
        var t;
        for (t in e) if (('data' !== t || !pe.isEmptyObject(e[t])) && 'toJSON' !== t) return !1;
        return !0
    }

    function c(e, t, n, r) {
        if (He(e)) {
            var i,
                o,
                a = pe.expando,
                s = e.nodeType,
                u = s ? pe.cache : e,
                l = s ? e[a] : e[a] && a;
            if (l && u[l] && (r || u[l].data) || void 0 !== n || 'string' != typeof t) return l || (l = s ? e[a] = ne.pop() || pe.guid++ : a),
            u[l] || (u[l] = s ? {}
                : {
                    toJSON: pe.noop
                }),
            'object' != typeof t && 'function' != typeof t || (r ? u[l] = pe.extend(u[l], t) : u[l].data = pe.extend(u[l].data, t)),
                o = u[l],
            r || (o.data || (o.data = {}), o = o.data),
            void 0 !== n && (o[pe.camelCase(t)] = n),
                'string' == typeof t ? (i = o[t], null == i && (i = o[pe.camelCase(t)])) : i = o,
                i
        }
    }

    function f(e, t, n) {
        if (He(e)) {
            var r,
                i,
                o = e.nodeType,
                a = o ? pe.cache : e,
                s = o ? e[pe.expando] : pe.expando;
            if (a[s]) {
                if (t && (r = n ? a[s] : a[s].data)) {
                    pe.isArray(t) ? t = t.concat(pe.map(t, pe.camelCase)) : t in r ? t = [
                        t
                    ] : (t = pe.camelCase(t), t = t in r ? [
                        t
                    ] : t.split(' ')),
                        i = t.length;
                    for (; i--;) delete r[t[i]];
                    if (n ? !l(r) : !pe.isEmptyObject(r)) return
                }
                (n || (delete a[s].data, l(a[s]))) && (o ? pe.cleanData([e], !0) : fe.deleteExpando || a != a.window ? delete a[s] : a[s] = void 0)
            }
        }
    }

    function d(e, t, n, r) {
        var i,
            o = 1,
            a = 20,
            s = r ? function () {
                    return r.cur()
                }
                : function () {
                    return pe.css(e, t, '')
                },
            u = s(),
            l = n && n[3] || (pe.cssNumber[t] ? '' : 'px'),
            c = (pe.cssNumber[t] || 'px' !== l && +u) && Me.exec(pe.css(e, t));
        if (c && c[3] !== l) {
            l = l || c[3],
                n = n || [],
                c = +u || 1;
            do o = o || '.5',
                c /= o,
                pe.style(e, t, c + l);
            while (o !== (o = s() / u) && 1 !== o && --a)
        }
        return n && (c = +c || +u || 0, i = n[1] ? c + (n[1] + 1) * n[2] : +n[2], r && (r.unit = l, r.start = c, r.end = i)),
            i
    }

    function p(e) {
        var t = ze.split('|'),
            n = e.createDocumentFragment();
        if (n.createElement) for (; t.length;) n.createElement(t.pop());
        return n
    }

    function h(e, t) {
        var n,
            r,
            i = 0,
            o = 'undefined' != typeof e.getElementsByTagName ? e.getElementsByTagName(t || '*') : 'undefined' != typeof e.querySelectorAll ? e.querySelectorAll(t || '*') : void 0;
        if (!o) for (o = [], n = e.childNodes || e; null != (r = n[i]); i++) !t || pe.nodeName(r, t) ? o.push(r) : pe.merge(o, h(r, t));
        return void 0 === t || t && pe.nodeName(e, t) ? pe.merge([e], o) : o
    }

    function g(e, t) {
        for (var n, r = 0; null != (n = e[r]); r++) pe._data(n, 'globalEval', !t || pe._data(t[r], 'globalEval'))
    }

    function m(e) {
        Be.test(e.type) && (e.defaultChecked = e.checked)
    }

    function y(e, t, n, r, i) {
        for (var o, a, s, u, l, c, f, d = e.length, y = p(t), v = [], x = 0; x < d; x++) if (a = e[x], a || 0 === a) if ('object' === pe.type(a)) pe.merge(v, a.nodeType ? [
            a
        ] : a);
        else if (Ue.test(a)) {
            for (u = u || y.appendChild(t.createElement('div')), l = (We.exec(a) || [
                '',
                ''
            ]) [1].toLowerCase(), f = Xe[l] || Xe._default, u.innerHTML = f[1] + pe.htmlPrefilter(a) + f[2], o = f[0]; o--;) u = u.lastChild;
            if (!fe.leadingWhitespace && $e.test(a) && v.push(t.createTextNode($e.exec(a) [0])), !fe.tbody) for (a = 'table' !== l || Ve.test(a) ? '<table>' !== f[1] || Ve.test(a) ? 0 : u : u.firstChild, o = a && a.childNodes.length; o--;) pe.nodeName(c = a.childNodes[o], 'tbody') && !c.childNodes.length && a.removeChild(c);
            for (pe.merge(v, u.childNodes), u.textContent = ''; u.firstChild;) u.removeChild(u.firstChild);
            u = y.lastChild
        } else v.push(t.createTextNode(a));
        for (u && y.removeChild(u), fe.appendChecked || pe.grep(h(v, 'input'), m), x = 0; a = v[x++];) if (r && pe.inArray(a, r) > -1) i && i.push(a);
        else if (s = pe.contains(a.ownerDocument, a), u = h(y.appendChild(a), 'script'), s && g(u), n) for (o = 0; a = u[o++];) Ie.test(a.type || '') && n.push(a);
        return u = null,
            y
    }

    function v() {
        return !0
    }

    function x() {
        return !1
    }

    function b() {
        try {
            return re.activeElement
        } catch (e) {
        }
    }

    function w(e, t, n, r, i, o) {
        var a,
            s;
        if ('object' == typeof t) {
            'string' != typeof n && (r = r || n, n = void 0);
            for (s in t) w(e, s, n, r, t[s], o);
            return e
        }
        if (null == r && null == i ? (i = n, r = n = void 0) : null == i && ('string' == typeof n ? (i = r, r = void 0) : (i = r, r = n, n = void 0)), i === !1) i = x;
        else if (!i) return e;
        return 1 === o && (a = i, i = function (e) {
            return pe().off(e),
                a.apply(this, arguments)
        }, i.guid = a.guid || (a.guid = pe.guid++)),
            e.each(function () {
                pe.event.add(this, t, i, r, n)
            })
    }

    function T(e, t) {
        return pe.nodeName(e, 'table') && pe.nodeName(11 !== t.nodeType ? t : t.firstChild, 'tr') ? e.getElementsByTagName('tbody') [0] || e.appendChild(e.ownerDocument.createElement('tbody')) : e
    }

    function C(e) {
        return e.type = (null !== pe.find.attr(e, 'type')) + '/' + e.type,
            e
    }

    function E(e) {
        var t = it.exec(e.type);
        return t ? e.type = t[1] : e.removeAttribute('type'),
            e
    }

    function N(e, t) {
        if (1 === t.nodeType && pe.hasData(e)) {
            var n,
                r,
                i,
                o = pe._data(e),
                a = pe._data(t, o),
                s = o.events;
            if (s) {
                delete a.handle,
                    a.events = {};
                for (n in s) for (r = 0, i = s[n].length; r < i; r++) pe.event.add(t, n, s[n][r])
            }
            a.data && (a.data = pe.extend({}, a.data))
        }
    }

    function k(e, t) {
        var n,
            r,
            i;
        if (1 === t.nodeType) {
            if (n = t.nodeName.toLowerCase(), !fe.noCloneEvent && t[pe.expando]) {
                i = pe._data(t);
                for (r in i.events) pe.removeEvent(t, r, i.handle);
                t.removeAttribute(pe.expando)
            }
            'script' === n && t.text !== e.text ? (C(t).text = e.text, E(t)) : 'object' === n ? (t.parentNode && (t.outerHTML = e.outerHTML), fe.html5Clone && e.innerHTML && !pe.trim(t.innerHTML) && (t.innerHTML = e.innerHTML)) : 'input' === n && Be.test(e.type) ? (t.defaultChecked = t.checked = e.checked, t.value !== e.value && (t.value = e.value)) : 'option' === n ? t.defaultSelected = t.selected = e.defaultSelected : 'input' !== n && 'textarea' !== n || (t.defaultValue = e.defaultValue)
        }
    }

    function S(e, t, n, r) {
        t = oe.apply([], t);
        var i,
            o,
            a,
            s,
            u,
            l,
            c = 0,
            f = e.length,
            d = f - 1,
            p = t[0],
            g = pe.isFunction(p);
        if (g || f > 1 && 'string' == typeof p && !fe.checkClone && rt.test(p)) return e.each(function (i) {
            var o = e.eq(i);
            g && (t[0] = p.call(this, i, o.html())),
                S(o, t, n, r)
        });
        if (f && (l = y(t, e[0].ownerDocument, !1, e, r), i = l.firstChild, 1 === l.childNodes.length && (l = i), i || r)) {
            for (s = pe.map(h(l, 'script'), C), a = s.length; c < f; c++) o = l,
            c !== d && (o = pe.clone(o, !0, !0), a && pe.merge(s, h(o, 'script'))),
                n.call(e[c], o, c);
            if (a) for (u = s[s.length - 1].ownerDocument, pe.map(s, E), c = 0; c < a; c++) o = s[c],
            Ie.test(o.type || '') && !pe._data(o, 'globalEval') && pe.contains(u, o) && (o.src ? pe._evalUrl && pe._evalUrl(o.src) : pe.globalEval((o.text || o.textContent || o.innerHTML || '').replace(ot, '')));
            l = i = null
        }
        return e
    }

    function A(e, t, n) {
        for (var r, i = t ? pe.filter(t, e) : e, o = 0; null != (r = i[o]); o++) n || 1 !== r.nodeType || pe.cleanData(h(r)),
        r.parentNode && (n && pe.contains(r.ownerDocument, r) && g(h(r, 'script')), r.parentNode.removeChild(r));
        return e
    }

    function D(e, t) {
        var n = pe(t.createElement(e)).appendTo(t.body),
            r = pe.css(n[0], 'display');
        return n.detach(),
            r
    }

    function j(e) {
        var t = re,
            n = lt[e];
        return n || (n = D(e, t), 'none' !== n && n || (ut = (ut || pe('<iframe frameborder=\'0\' width=\'0\' height=\'0\'/>')).appendTo(t.documentElement), t = (ut[0].contentWindow || ut[0].contentDocument).document, t.write(), t.close(), n = D(e, t), ut.detach()), lt[e] = n),
            n
    }

    function L(e, t) {
        return {
            get: function () {
                return e() ? void delete this.get : (this.get = t).apply(this, arguments)
            }
        }
    }

    function H(e) {
        if (e in Et) return e;
        for (var t = e.charAt(0).toUpperCase() + e.slice(1), n = Ct.length; n--;) if (e = Ct[n] + t, e in Et) return e
    }

    function q(e, t) {
        for (var n, r, i, o = [], a = 0, s = e.length; a < s; a++) r = e[a],
        r.style && (o[a] = pe._data(r, 'olddisplay'), n = r.style.display, t ? (o[a] || 'none' !== n || (r.style.display = ''), '' === r.style.display && Re(r) && (o[a] = pe._data(r, 'olddisplay', j(r.nodeName)))) : (i = Re(r), (n && 'none' !== n || !i) && pe._data(r, 'olddisplay', i ? n : pe.css(r, 'display'))));
        for (a = 0; a < s; a++) r = e[a],
        r.style && (t && 'none' !== r.style.display && '' !== r.style.display || (r.style.display = t ? o[a] || '' : 'none'));
        return e
    }

    function _(e, t, n) {
        var r = bt.exec(t);
        return r ? Math.max(0, r[1] - (n || 0)) + (r[2] || 'px') : t
    }

    function F(e, t, n, r, i) {
        for (var o = n === (r ? 'border' : 'content') ? 4 : 'width' === t ? 1 : 0, a = 0; o < 4; o += 2) 'margin' === n && (a += pe.css(e, n + Oe[o], !0, i)),
            r ? ('content' === n && (a -= pe.css(e, 'padding' + Oe[o], !0, i)), 'margin' !== n && (a -= pe.css(e, 'border' + Oe[o] + 'Width', !0, i))) : (a += pe.css(e, 'padding' + Oe[o], !0, i), 'padding' !== n && (a += pe.css(e, 'border' + Oe[o] + 'Width', !0, i)));
        return a
    }

    function M(t, n, r) {
        var i = !0,
            o = 'width' === n ? t.offsetWidth : t.offsetHeight,
            a = ht(t),
            s = fe.boxSizing && 'border-box' === pe.css(t, 'boxSizing', !1, a);
        if (re.msFullscreenElement && e.top !== e && t.getClientRects().length && (o = Math.round(100 * t.getBoundingClientRect() [n])), o <= 0 || null == o) {
            if (o = gt(t, n, a), (o < 0 || null == o) && (o = t.style[n]), ft.test(o)) return o;
            i = s && (fe.boxSizingReliable() || o === t.style[n]),
                o = parseFloat(o) || 0
        }
        return o + F(t, n, r || (s ? 'border' : 'content'), i, a) + 'px'
    }

    function O(e, t, n, r, i) {
        return new O.prototype.init(e, t, n, r, i)
    }

    function R() {
        return e.setTimeout(function () {
            Nt = void 0
        }),
            Nt = pe.now()
    }

    function P(e, t) {
        var n,
            r = {
                height: e
            },
            i = 0;
        for (t = t ? 1 : 0; i < 4; i += 2 - t) n = Oe[i],
            r['margin' + n] = r['padding' + n] = e;
        return t && (r.opacity = r.width = e),
            r
    }

    function B(e, t, n) {
        for (var r, i = ($.tweeners[t] || []).concat($.tweeners['*']), o = 0, a = i.length; o < a; o++) if (r = i[o].call(n, t, e)) return r
    }

    function W(e, t, n) {
        var r,
            i,
            o,
            a,
            s,
            u,
            l,
            c,
            f = this,
            d = {},
            p = e.style,
            h = e.nodeType && Re(e),
            g = pe._data(e, 'fxshow');
        n.queue || (s = pe._queueHooks(e, 'fx'), null == s.unqueued && (s.unqueued = 0, u = s.empty.fire, s.empty.fire = function () {
            s.unqueued || u()
        }), s.unqueued++, f.always(function () {
            f.always(function () {
                s.unqueued--,
                pe.queue(e, 'fx').length || s.empty.fire()
            })
        })),
        1 === e.nodeType && ('height' in t || 'width' in t) && (n.overflow = [
            p.overflow,
            p.overflowX,
            p.overflowY
        ], l = pe.css(e, 'display'), c = 'none' === l ? pe._data(e, 'olddisplay') || j(e.nodeName) : l, 'inline' === c && 'none' === pe.css(e, 'float') && (fe.inlineBlockNeedsLayout && 'inline' !== j(e.nodeName) ? p.zoom = 1 : p.display = 'inline-block')),
        n.overflow && (p.overflow = 'hidden', fe.shrinkWrapBlocks() || f.always(function () {
            p.overflow = n.overflow[0],
                p.overflowX = n.overflow[1],
                p.overflowY = n.overflow[2]
        }));
        for (r in t) if (i = t[r], St.exec(i)) {
            if (delete t[r], o = o || 'toggle' === i, i === (h ? 'hide' : 'show')) {
                if ('show' !== i || !g || void 0 === g[r]) continue;
                h = !0
            }
            d[r] = g && g[r] || pe.style(e, r)
        } else l = void 0;
        if (pe.isEmptyObject(d)) 'inline' === ('none' === l ? j(e.nodeName) : l) && (p.display = l);
        else {
            g ? 'hidden' in g && (h = g.hidden) : g = pe._data(e, 'fxshow', {}),
            o && (g.hidden = !h),
                h ? pe(e).show() : f.done(function () {
                    pe(e).hide()
                }),
                f.done(function () {
                    var t;
                    pe._removeData(e, 'fxshow');
                    for (t in d) pe.style(e, t, d[t])
                });
            for (r in d) a = B(h ? g[r] : 0, r, f),
            r in g || (g[r] = a.start, h && (a.end = a.start, a.start = 'width' === r || 'height' === r ? 1 : 0))
        }
    }

    function I(e, t) {
        var n,
            r,
            i,
            o,
            a;
        for (n in e) if (r = pe.camelCase(n), i = t[r], o = e[n], pe.isArray(o) && (i = o[1], o = e[n] = o[0]), n !== r && (e[r] = o, delete e[n]), a = pe.cssHooks[r], a && 'expand' in a) {
            o = a.expand(o),
                delete e[r];
            for (n in o) n in e || (e[n] = o[n], t[n] = i)
        } else t[r] = i
    }

    function $(e, t, n) {
        var r,
            i,
            o = 0,
            a = $.prefilters.length,
            s = pe.Deferred().always(function () {
                delete u.elem
            }),
            u = function () {
                if (i) return !1;
                for (var t = Nt || R(), n = Math.max(0, l.startTime + l.duration - t), r = n / l.duration || 0, o = 1 - r, a = 0, u = l.tweens.length; a < u; a++) l.tweens[a].run(o);
                return s.notifyWith(e, [
                    l,
                    o,
                    n
                ]),
                    o < 1 && u ? n : (s.resolveWith(e, [
                        l
                    ]), !1)
            },
            l = s.promise({
                elem: e,
                props: pe.extend({}, t),
                opts: pe.extend(!0, {
                    specialEasing: {},
                    easing: pe.easing._default
                }, n),
                originalProperties: t,
                originalOptions: n,
                startTime: Nt || R(),
                duration: n.duration,
                tweens: [],
                createTween: function (t, n) {
                    var r = pe.Tween(e, l.opts, t, n, l.opts.specialEasing[t] || l.opts.easing);
                    return l.tweens.push(r),
                        r
                },
                stop: function (t) {
                    var n = 0,
                        r = t ? l.tweens.length : 0;
                    if (i) return this;
                    for (i = !0; n < r; n++) l.tweens[n].run(1);
                    return t ? (s.notifyWith(e, [
                        l,
                        1,
                        0
                    ]), s.resolveWith(e, [
                        l,
                        t
                    ])) : s.rejectWith(e, [
                        l,
                        t
                    ]),
                        this
                }
            }),
            c = l.props;
        for (I(c, l.opts.specialEasing); o < a; o++) if (r = $.prefilters[o].call(l, e, c, l.opts)) return pe.isFunction(r.stop) && (pe._queueHooks(l.elem, l.opts.queue).stop = pe.proxy(r.stop, r)),
            r;
        return pe.map(c, B, l),
        pe.isFunction(l.opts.start) && l.opts.start.call(e, l),
            pe.fx.timer(pe.extend(u, {
                elem: e,
                anim: l,
                queue: l.opts.queue
            })),
            l.progress(l.opts.progress).done(l.opts.done, l.opts.complete).fail(l.opts.fail).always(l.opts.always)
    }

    function z(e) {
        return pe.attr(e, 'class') || ''
    }

    function X(e) {
        return function (t, n) {
            'string' != typeof t && (n = t, t = '*');
            var r,
                i = 0,
                o = t.toLowerCase().match(De) || [];
            if (pe.isFunction(n)) for (; r = o[i++];) '+' === r.charAt(0) ? (r = r.slice(1) || '*', (e[r] = e[r] || []).unshift(n)) : (e[r] = e[r] || []).push(n)
        }
    }

    function U(e, t, n, r) {
        function i(s) {
            var u;
            return o[s] = !0,
                pe.each(e[s] || [], function (e, s) {
                    var l = s(t, n, r);
                    return 'string' != typeof l || a || o[l] ? a ? !(u = l) : void 0 : (t.dataTypes.unshift(l), i(l), !1)
                }),
                u
        }

        var o = {},
            a = e === Qt;
        return i(t.dataTypes[0]) || !o['*'] && i('*')
    }

    function V(e, t) {
        var n,
            r,
            i = pe.ajaxSettings.flatOptions || {};
        for (r in t) void 0 !== t[r] && ((i[r] ? e : n || (n = {})) [r] = t[r]);
        return n && pe.extend(!0, e, n),
            e
    }

    function Y(e, t, n) {
        for (var r, i, o, a, s = e.contents, u = e.dataTypes; '*' === u[0];) u.shift(),
        void 0 === i && (i = e.mimeType || t.getResponseHeader('Content-Type'));
        if (i) for (a in s) if (s[a] && s[a].test(i)) {
            u.unshift(a);
            break
        }
        if (u[0] in n) o = u[0];
        else {
            for (a in n) {
                if (!u[0] || e.converters[a + ' ' + u[0]]) {
                    o = a;
                    break
                }
                r || (r = a)
            }
            o = o || r
        }
        if (o) return o !== u[0] && u.unshift(o),
            n[o]
    }

    function J(e, t, n, r) {
        var i,
            o,
            a,
            s,
            u,
            l = {},
            c = e.dataTypes.slice();
        if (c[1]) for (a in e.converters) l[a.toLowerCase()] = e.converters[a];
        for (o = c.shift(); o;) if (e.responseFields[o] && (n[e.responseFields[o]] = t), !u && r && e.dataFilter && (t = e.dataFilter(t, e.dataType)), u = o, o = c.shift()) if ('*' === o) o = u;
        else if ('*' !== u && u !== o) {
            if (a = l[u + ' ' + o] || l['* ' + o], !a) for (i in l) if (s = i.split(' '), s[1] === o && (a = l[u + ' ' + s[0]] || l['* ' + s[0]])) {
                a === !0 ? a = l[i] : l[i] !== !0 && (o = s[0], c.unshift(s[1]));
                break
            }
            if (a !== !0) if (a && e['throws']) t = a(t);
            else try {
                    t = a(t)
                } catch (f) {
                    return {
                        state: 'parsererror',
                        error: a ? f : 'No conversion from ' + u + ' to ' + o
                    }
                }
        }
        return {
            state: 'success',
            data: t
        }
    }

    function G(e) {
        return e.style && e.style.display || pe.css(e, 'display')
    }

    function K(e) {
        for (; e && 1 === e.nodeType;) {
            if ('none' === G(e) || 'hidden' === e.type) return !0;
            e = e.parentNode
        }
        return !1
    }

    function Q(e, t, n, r) {
        var i;
        if (pe.isArray(t)) pe.each(t, function (t, i) {
            n || rn.test(e) ? r(e, i) : Q(e + '[' + ('object' == typeof i && null != i ? t : '') + ']', i, n, r)
        });
        else if (n || 'object' !== pe.type(t)) r(e, t);
        else for (i in t) Q(e + '[' + i + ']', t[i], n, r)
    }

    function Z() {
        try {
            return new e.XMLHttpRequest
        } catch (t) {
        }
    }

    function ee() {
        try {
            return new e.ActiveXObject('Microsoft.XMLHTTP')
        } catch (t) {
        }
    }

    function te(e) {
        return pe.isWindow(e) ? e : 9 === e.nodeType && (e.defaultView || e.parentWindow)
    }

    var ne = [],
        re = e.document,
        ie = ne.slice,
        oe = ne.concat,
        ae = ne.push,
        se = ne.indexOf,
        ue = {},
        le = ue.toString,
        ce = ue.hasOwnProperty,
        fe = {},
        de = '1.12.3',
        pe = function (e, t) {
            return new pe.fn.init(e, t)
        },
        he = /^[\s\uFEFF\xA0]+|[\s\uFEFF\xA0]+$/g,
        ge = /^-ms-/,
        me = /-([\da-z])/gi,
        ye = function (e, t) {
            return t.toUpperCase()
        };
    pe.fn = pe.prototype = {
        jquery: de,
        constructor: pe,
        selector: '',
        length: 0,
        toArray: function () {
            return ie.call(this)
        },
        get: function (e) {
            return null != e ? e < 0 ? this[e + this.length] : this[e] : ie.call(this)
        },
        pushStack: function (e) {
            var t = pe.merge(this.constructor(), e);
            return t.prevObject = this,
                t.context = this.context,
                t
        },
        each: function (e) {
            return pe.each(this, e)
        },
        map: function (e) {
            return this.pushStack(pe.map(this, function (t, n) {
                return e.call(t, n, t)
            }))
        },
        slice: function () {
            return this.pushStack(ie.apply(this, arguments))
        },
        first: function () {
            return this.eq(0)
        },
        last: function () {
            return this.eq(-1)
        },
        eq: function (e) {
            var t = this.length,
                n = +e + (e < 0 ? t : 0);
            return this.pushStack(n >= 0 && n < t ? [
                this[n]
            ] : [])
        },
        end: function () {
            return this.prevObject || this.constructor()
        },
        push: ae,
        sort: ne.sort,
        splice: ne.splice
    },
        pe.extend = pe.fn.extend = function () {
            var e,
                t,
                n,
                r,
                i,
                o,
                a = arguments[0] || {},
                s = 1,
                u = arguments.length,
                l = !1;
            for ('boolean' == typeof a && (l = a, a = arguments[s] || {}, s++), 'object' == typeof a || pe.isFunction(a) || (a = {}), s === u && (a = this, s--); s < u; s++) if (null != (i = arguments[s])) for (r in i) e = a[r],
                n = i[r],
            a !== n && (l && n && (pe.isPlainObject(n) || (t = pe.isArray(n))) ? (t ? (t = !1, o = e && pe.isArray(e) ? e : []) : o = e && pe.isPlainObject(e) ? e : {}, a[r] = pe.extend(l, o, n)) : void 0 !== n && (a[r] = n));
            return a
        },
        pe.extend({
            expando: 'jQuery' + (de + Math.random()).replace(/\D/g, ''),
            isReady: !0,
            error: function (e) {
                throw new Error(e)
            },
            noop: function () {
            },
            isFunction: function (e) {
                return 'function' === pe.type(e)
            },
            isArray: Array.isArray || function (e) {
                return 'array' === pe.type(e)
            },
            isWindow: function (e) {
                return null != e && e == e.window
            },
            isNumeric: function (e) {
                var t = e && e.toString();
                return !pe.isArray(e) && t - parseFloat(t) + 1 >= 0
            },
            isEmptyObject: function (e) {
                var t;
                for (t in e) return !1;
                return !0
            },
            isPlainObject: function (e) {
                var t;
                if (!e || 'object' !== pe.type(e) || e.nodeType || pe.isWindow(e)) return !1;
                try {
                    if (e.constructor && !ce.call(e, 'constructor') && !ce.call(e.constructor.prototype, 'isPrototypeOf')) return !1
                } catch (n) {
                    return !1
                }
                if (!fe.ownFirst) for (t in e) return ce.call(e, t);
                for (t in e) ;
                return void 0 === t || ce.call(e, t)
            },
            type: function (e) {
                return null == e ? e + '' : 'object' == typeof e || 'function' == typeof e ? ue[le.call(e)] || 'object' : typeof e
            },
            globalEval: function (t) {
                t && pe.trim(t) && (e.execScript || function (t) {
                    e.eval.call(e, t)
                })(t)
            },
            camelCase: function (e) {
                return e.replace(ge, 'ms-').replace(me, ye)
            },
            nodeName: function (e, t) {
                return e.nodeName && e.nodeName.toLowerCase() === t.toLowerCase()
            },
            each: function (e, t) {
                var r,
                    i = 0;
                if (n(e)) for (r = e.length; i < r && t.call(e[i], i, e[i]) !== !1; i++) ;
                else for (i in e) if (t.call(e[i], i, e[i]) === !1) break;
                return e
            },
            trim: function (e) {
                return null == e ? '' : (e + '').replace(he, '')
            },
            makeArray: function (e, t) {
                var r = t || [];
                return null != e && (n(Object(e)) ? pe.merge(r, 'string' == typeof e ? [
                    e
                ] : e) : ae.call(r, e)),
                    r
            },
            inArray: function (e, t, n) {
                var r;
                if (t) {
                    if (se) return se.call(t, e, n);
                    for (r = t.length, n = n ? n < 0 ? Math.max(0, r + n) : n : 0; n < r; n++) if (n in t && t[n] === e) return n
                }
                return -1
            },
            merge: function (e, t) {
                for (var n = +t.length, r = 0, i = e.length; r < n;) e[i++] = t[r++];
                if (n !== n) for (; void 0 !== t[r];) e[i++] = t[r++];
                return e.length = i,
                    e
            },
            grep: function (e, t, n) {
                for (var r, i = [], o = 0, a = e.length, s = !n; o < a; o++) r = !t(e[o], o),
                r !== s && i.push(e[o]);
                return i
            },
            map: function (e, t, r) {
                var i,
                    o,
                    a = 0,
                    s = [];
                if (n(e)) for (i = e.length; a < i; a++) o = t(e[a], a, r),
                null != o && s.push(o);
                else for (a in e) o = t(e[a], a, r),
                null != o && s.push(o);
                return oe.apply([], s)
            },
            guid: 1,
            proxy: function (e, t) {
                var n,
                    r,
                    i;
                if ('string' == typeof t && (i = e[t], t = e, e = i), pe.isFunction(e)) return n = ie.call(arguments, 2),
                    r = function () {
                        return e.apply(t || this, n.concat(ie.call(arguments)))
                    },
                    r.guid = e.guid = e.guid || pe.guid++,
                    r
            },
            now: function () {
                return +new Date
            },
            support: fe
        }),
    'function' == typeof Symbol && (pe.fn[Symbol.iterator] = ne[Symbol.iterator]),
        pe.each('Boolean Number String Function Array Date RegExp Object Error Symbol'.split(' '), function (e, t) {
            ue['[object ' + t + ']'] = t.toLowerCase()
        });
    var ve = function (e) {
        function t(e, t, n, r) {
            var i,
                o,
                a,
                s,
                u,
                l,
                f,
                p,
                h = t && t.ownerDocument,
                g = t ? t.nodeType : 9;
            if (n = n || [], 'string' != typeof e || !e || 1 !== g && 9 !== g && 11 !== g) return n;
            if (!r && ((t ? t.ownerDocument || t : B) !== H && L(t), t = t || H, _)) {
                if (11 !== g && (l = ye.exec(e))) if (i = l[1]) {
                    if (9 === g) {
                        if (!(a = t.getElementById(i))) return n;
                        if (a.id === i) return n.push(a),
                            n
                    } else if (h && (a = h.getElementById(i)) && R(t, a) && a.id === i) return n.push(a),
                        n
                } else {
                    if (l[2]) return Q.apply(n, t.getElementsByTagName(e)),
                        n;
                    if ((i = l[3]) && w.getElementsByClassName && t.getElementsByClassName) return Q.apply(n, t.getElementsByClassName(i)),
                        n
                }
                if (w.qsa && !X[e + ' '] && (!F || !F.test(e))) {
                    if (1 !== g) h = t,
                        p = e;
                    else if ('object' !== t.nodeName.toLowerCase()) {
                        for ((s = t.getAttribute('id')) ? s = s.replace(xe, '\\$&') : t.setAttribute('id', s = P), f = N(e), o = f.length, u = de.test(s) ? '#' + s : '[id=\'' + s + '\']'; o--;) f[o] = u + ' ' + d(f[o]);
                        p = f.join(','),
                            h = ve.test(e) && c(t.parentNode) || t
                    }
                    if (p) try {
                        return Q.apply(n, h.querySelectorAll(p)),
                            n
                    } catch (m) {
                    } finally {
                        s === P && t.removeAttribute('id')
                    }
                }
            }
            return S(e.replace(se, '$1'), t, n, r)
        }

        function n() {
            function e(n, r) {
                return t.push(n + ' ') > T.cacheLength && delete e[t.shift()],
                    e[n + ' '] = r
            }

            var t = [];
            return e
        }

        function r(e) {
            return e[P] = !0,
                e
        }

        function i(e) {
            var t = H.createElement('div');
            try {
                return !!e(t)
            } catch (n) {
                return !1
            } finally {
                t.parentNode && t.parentNode.removeChild(t),
                    t = null
            }
        }

        function o(e, t) {
            for (var n = e.split('|'), r = n.length; r--;) T.attrHandle[n[r]] = t
        }

        function a(e, t) {
            var n = t && e,
                r = n && 1 === e.nodeType && 1 === t.nodeType && (~t.sourceIndex || V) - (~e.sourceIndex || V);
            if (r) return r;
            if (n) for (; n = n.nextSibling;) if (n === t) return -1;
            return e ? 1 : -1
        }

        function s(e) {
            return function (t) {
                var n = t.nodeName.toLowerCase();
                return 'input' === n && t.type === e
            }
        }

        function u(e) {
            return function (t) {
                var n = t.nodeName.toLowerCase();
                return ('input' === n || 'button' === n) && t.type === e
            }
        }

        function l(e) {
            return r(function (t) {
                return t = +t,
                    r(function (n, r) {
                        for (var i, o = e([], n.length, t), a = o.length; a--;) n[i = o[a]] && (n[i] = !(r[i] = n[i]))
                    })
            })
        }

        function c(e) {
            return e && 'undefined' != typeof e.getElementsByTagName && e
        }

        function f() {
        }

        function d(e) {
            for (var t = 0, n = e.length, r = ''; t < n; t++) r += e[t].value;
            return r
        }

        function p(e, t, n) {
            var r = t.dir,
                i = n && 'parentNode' === r,
                o = I++;
            return t.first ? function (t, n, o) {
                    for (; t = t[r];) if (1 === t.nodeType || i) return e(t, n, o)
                }
                : function (t, n, a) {
                    var s,
                        u,
                        l,
                        c = [
                            W,
                            o
                        ];
                    if (a) {
                        for (; t = t[r];) if ((1 === t.nodeType || i) && e(t, n, a)) return !0
                    } else for (; t = t[r];) if (1 === t.nodeType || i) {
                        if (l = t[P] || (t[P] = {}), u = l[t.uniqueID] || (l[t.uniqueID] = {}), (s = u[r]) && s[0] === W && s[1] === o) return c[2] = s[2];
                        if (u[r] = c, c[2] = e(t, n, a)) return !0
                    }
                }
        }

        function h(e) {
            return e.length > 1 ? function (t, n, r) {
                    for (var i = e.length; i--;) if (!e[i](t, n, r)) return !1;
                    return !0
                }
                : e[0]
        }

        function g(e, n, r) {
            for (var i = 0, o = n.length; i < o; i++) t(e, n[i], r);
            return r
        }

        function m(e, t, n, r, i) {
            for (var o, a = [], s = 0, u = e.length, l = null != t; s < u; s++) (o = e[s]) && (n && !n(o, r, i) || (a.push(o), l && t.push(s)));
            return a
        }

        function y(e, t, n, i, o, a) {
            return i && !i[P] && (i = y(i)),
            o && !o[P] && (o = y(o, a)),
                r(function (r, a, s, u) {
                    var l,
                        c,
                        f,
                        d = [],
                        p = [],
                        h = a.length,
                        y = r || g(t || '*', s.nodeType ? [
                            s
                        ] : s, []),
                        v = !e || !r && t ? y : m(y, d, e, s, u),
                        x = n ? o || (r ? e : h || i) ? [] : a : v;
                    if (n && n(v, x, s, u), i) for (l = m(x, p), i(l, [], s, u), c = l.length; c--;) (f = l[c]) && (x[p[c]] = !(v[p[c]] = f));
                    if (r) {
                        if (o || e) {
                            if (o) {
                                for (l = [], c = x.length; c--;) (f = x[c]) && l.push(v[c] = f);
                                o(null, x = [], l, u)
                            }
                            for (c = x.length; c--;) (f = x[c]) && (l = o ? ee(r, f) : d[c]) > -1 && (r[l] = !(a[l] = f))
                        }
                    } else x = m(x === a ? x.splice(h, x.length) : x),
                        o ? o(null, a, x, u) : Q.apply(a, x)
                })
        }

        function v(e) {
            for (var t, n, r, i = e.length, o = T.relative[e[0].type], a = o || T.relative[' '], s = o ? 1 : 0, u = p(function (e) {
                return e === t
            }, a, !0), l = p(function (e) {
                return ee(t, e) > -1
            }, a, !0), c = [
                function (e, n, r) {
                    var i = !o && (r || n !== A) || ((t = n).nodeType ? u(e, n, r) : l(e, n, r));
                    return t = null,
                        i
                }
            ]; s < i; s++) if (n = T.relative[e[s].type]) c = [
                p(h(c), n)
            ];
            else {
                if (n = T.filter[e[s].type].apply(null, e[s].matches), n[P]) {
                    for (r = ++s; r < i && !T.relative[e[r].type]; r++) ;
                    return y(s > 1 && h(c), s > 1 && d(e.slice(0, s - 1).concat({
                        value: ' ' === e[s - 2].type ? '*' : ''
                    })).replace(se, '$1'), n, s < r && v(e.slice(s, r)), r < i && v(e = e.slice(r)), r < i && d(e))
                }
                c.push(n)
            }
            return h(c)
        }

        function x(e, n) {
            var i = n.length > 0,
                o = e.length > 0,
                a = function (r, a, s, u, l) {
                    var c,
                        f,
                        d,
                        p = 0,
                        h = '0',
                        g = r && [],
                        y = [],
                        v = A,
                        x = r || o && T.find.TAG('*', l),
                        b = W += null == v ? 1 : Math.random() || 0.1,
                        w = x.length;
                    for (l && (A = a === H || a || l); h !== w && null != (c = x[h]); h++) {
                        if (o && c) {
                            for (f = 0, a || c.ownerDocument === H || (L(c), s = !_); d = e[f++];) if (d(c, a || H, s)) {
                                u.push(c);
                                break
                            }
                            l && (W = b)
                        }
                        i && ((c = !d && c) && p--, r && g.push(c))
                    }
                    if (p += h, i && h !== p) {
                        for (f = 0; d = n[f++];) d(g, y, a, s);
                        if (r) {
                            if (p > 0) for (; h--;) g[h] || y[h] || (y[h] = G.call(u));
                            y = m(y)
                        }
                        Q.apply(u, y),
                        l && !r && y.length > 0 && p + n.length > 1 && t.uniqueSort(u)
                    }
                    return l && (W = b, A = v),
                        g
                };
            return i ? r(a) : a
        }

        var b,
            w,
            T,
            C,
            E,
            N,
            k,
            S,
            A,
            D,
            j,
            L,
            H,
            q,
            _,
            F,
            M,
            O,
            R,
            P = 'sizzle' + 1 * new Date,
            B = e.document,
            W = 0,
            I = 0,
            $ = n(),
            z = n(),
            X = n(),
            U = function (e, t) {
                return e === t && (j = !0),
                    0
            },
            V = 1 << 31,
            Y = {}.hasOwnProperty,
            J = [],
            G = J.pop,
            K = J.push,
            Q = J.push,
            Z = J.slice,
            ee = function (e, t) {
                for (var n = 0, r = e.length; n < r; n++) if (e[n] === t) return n;
                return -1
            },
            te = 'checked|selected|async|autofocus|autoplay|controls|defer|disabled|hidden|ismap|loop|multiple|open|readonly|required|scoped',
            ne = '[\\x20\\t\\r\\n\\f]',
            re = '(?:\\\\.|[\\w-]|[^\\x00-\\xa0])+',
            ie = '\\[' + ne + '*(' + re + ')(?:' + ne + '*([*^$|!~]?=)' + ne + '*(?:\'((?:\\\\.|[^\\\\\'])*)\'|"((?:\\\\.|[^\\\\"])*)"|(' + re + '))|)' + ne + '*\\]',
            oe = ':(' + re + ')(?:\\(((\'((?:\\\\.|[^\\\\\'])*)\'|"((?:\\\\.|[^\\\\"])*)")|((?:\\\\.|[^\\\\()[\\]]|' + ie + ')*)|.*)\\)|)',
            ae = new RegExp(ne + '+', 'g'),
            se = new RegExp('^' + ne + '+|((?:^|[^\\\\])(?:\\\\.)*)' + ne + '+$', 'g'),
            ue = new RegExp('^' + ne + '*,' + ne + '*'),
            le = new RegExp('^' + ne + '*([>+~]|' + ne + ')' + ne + '*'),
            ce = new RegExp('=' + ne + '*([^\\]\'"]*?)' + ne + '*\\]', 'g'),
            fe = new RegExp(oe),
            de = new RegExp('^' + re + '$'),
            pe = {
                ID: new RegExp('^#(' + re + ')'),
                CLASS: new RegExp('^\\.(' + re + ')'),
                TAG: new RegExp('^(' + re + '|[*])'),
                ATTR: new RegExp('^' + ie),
                PSEUDO: new RegExp('^' + oe),
                CHILD: new RegExp('^:(only|first|last|nth|nth-last)-(child|of-type)(?:\\(' + ne + '*(even|odd|(([+-]|)(\\d*)n|)' + ne + '*(?:([+-]|)' + ne + '*(\\d+)|))' + ne + '*\\)|)', 'i'),
                bool: new RegExp('^(?:' + te + ')$', 'i'),
                needsContext: new RegExp('^' + ne + '*[>+~]|:(even|odd|eq|gt|lt|nth|first|last)(?:\\(' + ne + '*((?:-\\d)?\\d*)' + ne + '*\\)|)(?=[^-]|$)', 'i')
            },
            he = /^(?:input|select|textarea|button)$/i,
            ge = /^h\d$/i,
            me = /^[^{]+\{\s*\[native \w/,
            ye = /^(?:#([\w-]+)|(\w+)|\.([\w-]+))$/,
            ve = /[+~]/,
            xe = /'|\\/g,
            be = new RegExp('\\\\([\\da-f]{1,6}' + ne + '?|(' + ne + ')|.)', 'ig'),
            we = function (e, t, n) {
                var r = '0x' + t - 65536;
                return r !== r || n ? t : r < 0 ? String.fromCharCode(r + 65536) : String.fromCharCode(r >> 10 | 55296, 1023 & r | 56320)
            },
            Te = function () {
                L()
            };
        try {
            Q.apply(J = Z.call(B.childNodes), B.childNodes),
                J[B.childNodes.length].nodeType
        } catch (Ce) {
            Q = {
                apply: J.length ? function (e, t) {
                        K.apply(e, Z.call(t))
                    }
                    : function (e, t) {
                        for (var n = e.length, r = 0; e[n++] = t[r++];) ;
                        e.length = n - 1
                    }
            }
        }
        w = t.support = {},
            E = t.isXML = function (e) {
                var t = e && (e.ownerDocument || e).documentElement;
                return !!t && 'HTML' !== t.nodeName
            },
            L = t.setDocument = function (e) {
                var t,
                    n,
                    r = e ? e.ownerDocument || e : B;
                return r !== H && 9 === r.nodeType && r.documentElement ? (H = r, q = H.documentElement, _ = !E(H), (n = H.defaultView) && n.top !== n && (n.addEventListener ? n.addEventListener('unload', Te, !1) : n.attachEvent && n.attachEvent('onunload', Te)), w.attributes = i(function (e) {
                    return e.className = 'i',
                        !e.getAttribute('className')
                }), w.getElementsByTagName = i(function (e) {
                    return e.appendChild(H.createComment('')),
                        !e.getElementsByTagName('*').length
                }), w.getElementsByClassName = me.test(H.getElementsByClassName), w.getById = i(function (e) {
                    return q.appendChild(e).id = P,
                    !H.getElementsByName || !H.getElementsByName(P).length
                }), w.getById ? (T.find.ID = function (e, t) {
                    if ('undefined' != typeof t.getElementById && _) {
                        var n = t.getElementById(e);
                        return n ? [
                            n
                        ] : []
                    }
                }, T.filter.ID = function (e) {
                    var t = e.replace(be, we);
                    return function (e) {
                        return e.getAttribute('id') === t
                    }
                }) : (delete T.find.ID, T.filter.ID = function (e) {
                    var t = e.replace(be, we);
                    return function (e) {
                        var n = 'undefined' != typeof e.getAttributeNode && e.getAttributeNode('id');
                        return n && n.value === t
                    }
                }), T.find.TAG = w.getElementsByTagName ? function (e, t) {
                        return 'undefined' != typeof t.getElementsByTagName ? t.getElementsByTagName(e) : w.qsa ? t.querySelectorAll(e) : void 0
                    }
                    : function (e, t) {
                        var n,
                            r = [],
                            i = 0,
                            o = t.getElementsByTagName(e);
                        if ('*' === e) {
                            for (; n = o[i++];) 1 === n.nodeType && r.push(n);
                            return r
                        }
                        return o
                    }, T.find.CLASS = w.getElementsByClassName && function (e, t) {
                    if ('undefined' != typeof t.getElementsByClassName && _) return t.getElementsByClassName(e)
                }, M = [], F = [], (w.qsa = me.test(H.querySelectorAll)) && (i(function (e) {
                    q.appendChild(e).innerHTML = '<a id=\'' + P + '\'></a><select id=\'' + P + '-\r\\\' msallowcapture=\'\'><option selected=\'\'></option></select>',
                    e.querySelectorAll('[msallowcapture^=\'\']').length && F.push('[*^$]=' + ne + '*(?:\'\'|"")'),
                    e.querySelectorAll('[selected]').length || F.push('\\[' + ne + '*(?:value|' + te + ')'),
                    e.querySelectorAll('[id~=' + P + '-]').length || F.push('~='),
                    e.querySelectorAll(':checked').length || F.push(':checked'),
                    e.querySelectorAll('a#' + P + '+*').length || F.push('.#.+[+~]')
                }), i(function (e) {
                    var t = H.createElement('input');
                    t.setAttribute('type', 'hidden'),
                        e.appendChild(t).setAttribute('name', 'D'),
                    e.querySelectorAll('[name=d]').length && F.push('name' + ne + '*[*^$|!~]?='),
                    e.querySelectorAll(':enabled').length || F.push(':enabled', ':disabled'),
                        e.querySelectorAll('*,:x'),
                        F.push(',.*:')
                })), (w.matchesSelector = me.test(O = q.matches || q.webkitMatchesSelector || q.mozMatchesSelector || q.oMatchesSelector || q.msMatchesSelector)) && i(function (e) {
                    w.disconnectedMatch = O.call(e, 'div'),
                        O.call(e, '[s!=\'\']:x'),
                        M.push('!=', oe)
                }), F = F.length && new RegExp(F.join('|')), M = M.length && new RegExp(M.join('|')), t = me.test(q.compareDocumentPosition), R = t || me.test(q.contains) ? function (e, t) {
                        var n = 9 === e.nodeType ? e.documentElement : e,
                            r = t && t.parentNode;
                        return e === r || !(!r || 1 !== r.nodeType || !(n.contains ? n.contains(r) : e.compareDocumentPosition && 16 & e.compareDocumentPosition(r)))
                    }
                    : function (e, t) {
                        if (t) for (; t = t.parentNode;) if (t === e) return !0;
                        return !1
                    }, U = t ? function (e, t) {
                        if (e === t) return j = !0,
                            0;
                        var n = !e.compareDocumentPosition - !t.compareDocumentPosition;
                        return n ? n : (n = (e.ownerDocument || e) === (t.ownerDocument || t) ? e.compareDocumentPosition(t) : 1, 1 & n || !w.sortDetached && t.compareDocumentPosition(e) === n ? e === H || e.ownerDocument === B && R(B, e) ? -1 : t === H || t.ownerDocument === B && R(B, t) ? 1 : D ? ee(D, e) - ee(D, t) : 0 : 4 & n ? -1 : 1)
                    }
                    : function (e, t) {
                        if (e === t) return j = !0,
                            0;
                        var n,
                            r = 0,
                            i = e.parentNode,
                            o = t.parentNode,
                            s = [
                                e
                            ],
                            u = [
                                t
                            ];
                        if (!i || !o) return e === H ? -1 : t === H ? 1 : i ? -1 : o ? 1 : D ? ee(D, e) - ee(D, t) : 0;
                        if (i === o) return a(e, t);
                        for (n = e; n = n.parentNode;) s.unshift(n);
                        for (n = t; n = n.parentNode;) u.unshift(n);
                        for (; s[r] === u[r];) r++;
                        return r ? a(s[r], u[r]) : s[r] === B ? -1 : u[r] === B ? 1 : 0
                    }, H) : H
            },
            t.matches = function (e, n) {
                return t(e, null, null, n)
            },
            t.matchesSelector = function (e, n) {
                if ((e.ownerDocument || e) !== H && L(e), n = n.replace(ce, '=\'$1\']'), w.matchesSelector && _ && !X[n + ' '] && (!M || !M.test(n)) && (!F || !F.test(n))) try {
                    var r = O.call(e, n);
                    if (r || w.disconnectedMatch || e.document && 11 !== e.document.nodeType) return r
                } catch (i) {
                }
                return t(n, H, null, [
                    e
                ]).length > 0
            },
            t.contains = function (e, t) {
                return (e.ownerDocument || e) !== H && L(e),
                    R(e, t)
            },
            t.attr = function (e, t) {
                (e.ownerDocument || e) !== H && L(e);
                var n = T.attrHandle[t.toLowerCase()],
                    r = n && Y.call(T.attrHandle, t.toLowerCase()) ? n(e, t, !_) : void 0;
                return void 0 !== r ? r : w.attributes || !_ ? e.getAttribute(t) : (r = e.getAttributeNode(t)) && r.specified ? r.value : null
            },
            t.error = function (e) {
                throw new Error('Syntax error, unrecognized expression: ' + e)
            },
            t.uniqueSort = function (e) {
                var t,
                    n = [],
                    r = 0,
                    i = 0;
                if (j = !w.detectDuplicates, D = !w.sortStable && e.slice(0), e.sort(U), j) {
                    for (; t = e[i++];) t === e[i] && (r = n.push(i));
                    for (; r--;) e.splice(n[r], 1)
                }
                return D = null,
                    e
            },
            C = t.getText = function (e) {
                var t,
                    n = '',
                    r = 0,
                    i = e.nodeType;
                if (i) {
                    if (1 === i || 9 === i || 11 === i) {
                        if ('string' == typeof e.textContent) return e.textContent;
                        for (e = e.firstChild; e; e = e.nextSibling) n += C(e)
                    } else if (3 === i || 4 === i) return e.nodeValue
                } else for (; t = e[r++];) n += C(t);
                return n
            },
            T = t.selectors = {
                cacheLength: 50,
                createPseudo: r,
                match: pe,
                attrHandle: {},
                find: {},
                relative: {
                    '>': {
                        dir: 'parentNode',
                        first: !0
                    },
                    ' ': {
                        dir: 'parentNode'
                    },
                    '+': {
                        dir: 'previousSibling',
                        first: !0
                    },
                    '~': {
                        dir: 'previousSibling'
                    }
                },
                preFilter: {
                    ATTR: function (e) {
                        return e[1] = e[1].replace(be, we),
                            e[3] = (e[3] || e[4] || e[5] || '').replace(be, we),
                        '~=' === e[2] && (e[3] = ' ' + e[3] + ' '),
                            e.slice(0, 4)
                    },
                    CHILD: function (e) {
                        return e[1] = e[1].toLowerCase(),
                            'nth' === e[1].slice(0, 3) ? (e[3] || t.error(e[0]), e[4] = +(e[4] ? e[5] + (e[6] || 1) : 2 * ('even' === e[3] || 'odd' === e[3])), e[5] = +(e[7] + e[8] || 'odd' === e[3])) : e[3] && t.error(e[0]),
                            e
                    },
                    PSEUDO: function (e) {
                        var t,
                            n = !e[6] && e[2];
                        return pe.CHILD.test(e[0]) ? null : (e[3] ? e[2] = e[4] || e[5] || '' : n && fe.test(n) && (t = N(n, !0)) && (t = n.indexOf(')', n.length - t) - n.length) && (e[0] = e[0].slice(0, t), e[2] = n.slice(0, t)), e.slice(0, 3))
                    }
                },
                filter: {
                    TAG: function (e) {
                        var t = e.replace(be, we).toLowerCase();
                        return '*' === e ? function () {
                                return !0
                            }
                            : function (e) {
                                return e.nodeName && e.nodeName.toLowerCase() === t
                            }
                    },
                    CLASS: function (e) {
                        var t = $[e + ' '];
                        return t || (t = new RegExp('(^|' + ne + ')' + e + '(' + ne + '|$)')) && $(e, function (e) {
                            return t.test('string' == typeof e.className && e.className || 'undefined' != typeof e.getAttribute && e.getAttribute('class') || '')
                        })
                    },
                    ATTR: function (e, n, r) {
                        return function (i) {
                            var o = t.attr(i, e);
                            return null == o ? '!=' === n : !n || (o += '', '=' === n ? o === r : '!=' === n ? o !== r : '^=' === n ? r && 0 === o.indexOf(r) : '*=' === n ? r && o.indexOf(r) > -1 : '$=' === n ? r && o.slice(-r.length) === r : '~=' === n ? (' ' + o.replace(ae, ' ') + ' ').indexOf(r) > -1 : '|=' === n && (o === r || o.slice(0, r.length + 1) === r + '-'))
                        }
                    },
                    CHILD: function (e, t, n, r, i) {
                        var o = 'nth' !== e.slice(0, 3),
                            a = 'last' !== e.slice(-4),
                            s = 'of-type' === t;
                        return 1 === r && 0 === i ? function (e) {
                                return !!e.parentNode
                            }
                            : function (t, n, u) {
                                var l,
                                    c,
                                    f,
                                    d,
                                    p,
                                    h,
                                    g = o !== a ? 'nextSibling' : 'previousSibling',
                                    m = t.parentNode,
                                    y = s && t.nodeName.toLowerCase(),
                                    v = !u && !s,
                                    x = !1;
                                if (m) {
                                    if (o) {
                                        for (; g;) {
                                            for (d = t; d = d[g];) if (s ? d.nodeName.toLowerCase() === y : 1 === d.nodeType) return !1;
                                            h = g = 'only' === e && !h && 'nextSibling'
                                        }
                                        return !0
                                    }
                                    if (h = [
                                        a ? m.firstChild : m.lastChild
                                    ], a && v) {
                                        for (d = m, f = d[P] || (d[P] = {}), c = f[d.uniqueID] || (f[d.uniqueID] = {}), l = c[e] || [], p = l[0] === W && l[1], x = p && l[2], d = p && m.childNodes[p]; d = ++p && d && d[g] || (x = p = 0) || h.pop();) if (1 === d.nodeType && ++x && d === t) {
                                            c[e] = [
                                                W,
                                                p,
                                                x
                                            ];
                                            break
                                        }
                                    } else if (v && (d = t, f = d[P] || (d[P] = {}), c = f[d.uniqueID] || (f[d.uniqueID] = {}), l = c[e] || [], p = l[0] === W && l[1], x = p), x === !1) for (; (d = ++p && d && d[g] || (x = p = 0) || h.pop()) && ((s ? d.nodeName.toLowerCase() !== y : 1 !== d.nodeType) || !++x || (v && (f = d[P] || (d[P] = {}), c = f[d.uniqueID] || (f[d.uniqueID] = {}), c[e] = [
                                        W,
                                        x
                                    ]), d !== t));) ;
                                    return x -= i,
                                    x === r || x % r === 0 && x / r >= 0
                                }
                            }
                    },
                    PSEUDO: function (e, n) {
                        var i,
                            o = T.pseudos[e] || T.setFilters[e.toLowerCase()] || t.error('unsupported pseudo: ' + e);
                        return o[P] ? o(n) : o.length > 1 ? (i = [
                            e,
                            e,
                            '',
                            n
                        ], T.setFilters.hasOwnProperty(e.toLowerCase()) ? r(function (e, t) {
                            for (var r, i = o(e, n), a = i.length; a--;) r = ee(e, i[a]),
                                e[r] = !(t[r] = i[a])
                        }) : function (e) {
                            return o(e, 0, i)
                        }) : o
                    }
                },
                pseudos: {
                    not: r(function (e) {
                        var t = [],
                            n = [],
                            i = k(e.replace(se, '$1'));
                        return i[P] ? r(function (e, t, n, r) {
                            for (var o, a = i(e, null, r, []), s = e.length; s--;) (o = a[s]) && (e[s] = !(t[s] = o))
                        }) : function (e, r, o) {
                            return t[0] = e,
                                i(t, null, o, n),
                                t[0] = null,
                                !n.pop()
                        }
                    }),
                    has: r(function (e) {
                        return function (n) {
                            return t(e, n).length > 0
                        }
                    }),
                    contains: r(function (e) {
                        return e = e.replace(be, we),
                            function (t) {
                                return (t.textContent || t.innerText || C(t)).indexOf(e) > -1
                            }
                    }),
                    lang: r(function (e) {
                        return de.test(e || '') || t.error('unsupported lang: ' + e),
                            e = e.replace(be, we).toLowerCase(),
                            function (t) {
                                var n;
                                do if (n = _ ? t.lang : t.getAttribute('xml:lang') || t.getAttribute('lang')) return n = n.toLowerCase(),
                                n === e || 0 === n.indexOf(e + '-');
                                while ((t = t.parentNode) && 1 === t.nodeType);
                                return !1
                            }
                    }),
                    target: function (t) {
                        var n = e.location && e.location.hash;
                        return n && n.slice(1) === t.id
                    },
                    root: function (e) {
                        return e === q
                    },
                    focus: function (e) {
                        return e === H.activeElement && (!H.hasFocus || H.hasFocus()) && !!(e.type || e.href || ~e.tabIndex)
                    },
                    enabled: function (e) {
                        return e.disabled === !1
                    },
                    disabled: function (e) {
                        return e.disabled === !0
                    },
                    checked: function (e) {
                        var t = e.nodeName.toLowerCase();
                        return 'input' === t && !!e.checked || 'option' === t && !!e.selected
                    },
                    selected: function (e) {
                        return e.parentNode && e.parentNode.selectedIndex,
                        e.selected === !0
                    },
                    empty: function (e) {
                        for (e = e.firstChild; e; e = e.nextSibling) if (e.nodeType < 6) return !1;
                        return !0
                    },
                    parent: function (e) {
                        return !T.pseudos.empty(e)
                    },
                    header: function (e) {
                        return ge.test(e.nodeName)
                    },
                    input: function (e) {
                        return he.test(e.nodeName)
                    },
                    button: function (e) {
                        var t = e.nodeName.toLowerCase();
                        return 'input' === t && 'button' === e.type || 'button' === t
                    },
                    text: function (e) {
                        var t;
                        return 'input' === e.nodeName.toLowerCase() && 'text' === e.type && (null == (t = e.getAttribute('type')) || 'text' === t.toLowerCase())
                    },
                    first: l(function () {
                        return [0]
                    }),
                    last: l(function (e, t) {
                        return [t - 1]
                    }),
                    eq: l(function (e, t, n) {
                        return [n < 0 ? n + t : n]
                    }),
                    even: l(function (e, t) {
                        for (var n = 0; n < t; n += 2) e.push(n);
                        return e
                    }),
                    odd: l(function (e, t) {
                        for (var n = 1; n < t; n += 2) e.push(n);
                        return e
                    }),
                    lt: l(function (e, t, n) {
                        for (var r = n < 0 ? n + t : n; --r >= 0;) e.push(r);
                        return e
                    }),
                    gt: l(function (e, t, n) {
                        for (var r = n < 0 ? n + t : n; ++r < t;) e.push(r);
                        return e
                    })
                }
            },
            T.pseudos.nth = T.pseudos.eq;
        for (b in {
            radio: !0,
            checkbox: !0,
            file: !0,
            password: !0,
            image: !0
        }) T.pseudos[b] = s(b);
        for (b in {
            submit: !0,
            reset: !0
        }) T.pseudos[b] = u(b);
        return f.prototype = T.filters = T.pseudos,
            T.setFilters = new f,
            N = t.tokenize = function (e, n) {
                var r,
                    i,
                    o,
                    a,
                    s,
                    u,
                    l,
                    c = z[e + ' '];
                if (c) return n ? 0 : c.slice(0);
                for (s = e, u = [], l = T.preFilter; s;) {
                    r && !(i = ue.exec(s)) || (i && (s = s.slice(i[0].length) || s), u.push(o = [])),
                        r = !1,
                    (i = le.exec(s)) && (r = i.shift(), o.push({
                        value: r,
                        type: i[0].replace(se, ' ')
                    }), s = s.slice(r.length));
                    for (a in T.filter) !(i = pe[a].exec(s)) || l[a] && !(i = l[a](i)) || (r = i.shift(), o.push({
                        value: r,
                        type: a,
                        matches: i
                    }), s = s.slice(r.length));
                    if (!r) break
                }
                return n ? s.length : s ? t.error(e) : z(e, u).slice(0)
            },
            k = t.compile = function (e, t) {
                var n,
                    r = [],
                    i = [],
                    o = X[e + ' '];
                if (!o) {
                    for (t || (t = N(e)), n = t.length; n--;) o = v(t[n]),
                        o[P] ? r.push(o) : i.push(o);
                    o = X(e, x(i, r)),
                        o.selector = e
                }
                return o
            },
            S = t.select = function (e, t, n, r) {
                var i,
                    o,
                    a,
                    s,
                    u,
                    l = 'function' == typeof e && e,
                    f = !r && N(e = l.selector || e);
                if (n = n || [], 1 === f.length) {
                    if (o = f[0] = f[0].slice(0), o.length > 2 && 'ID' === (a = o[0]).type && w.getById && 9 === t.nodeType && _ && T.relative[o[1].type]) {
                        if (t = (T.find.ID(a.matches[0].replace(be, we), t) || []) [0], !t) return n;
                        l && (t = t.parentNode),
                            e = e.slice(o.shift().value.length)
                    }
                    for (i = pe.needsContext.test(e) ? 0 : o.length; i-- && (a = o[i], !T.relative[s = a.type]);) if ((u = T.find[s]) && (r = u(a.matches[0].replace(be, we), ve.test(o[0].type) && c(t.parentNode) || t))) {
                        if (o.splice(i, 1), e = r.length && d(o), !e) return Q.apply(n, r),
                            n;
                        break
                    }
                }
                return (l || k(e, f))(r, t, !_, n, !t || ve.test(e) && c(t.parentNode) || t),
                    n
            },
            w.sortStable = P.split('').sort(U).join('') === P,
            w.detectDuplicates = !!j,
            L(),
            w.sortDetached = i(function (e) {
                return 1 & e.compareDocumentPosition(H.createElement('div'))
            }),
        i(function (e) {
            return e.innerHTML = '<a href=\'#\'></a>',
            '#' === e.firstChild.getAttribute('href')
        }) || o('type|href|height|width', function (e, t, n) {
            if (!n) return e.getAttribute(t, 'type' === t.toLowerCase() ? 1 : 2)
        }),
        w.attributes && i(function (e) {
            return e.innerHTML = '<input/>',
                e.firstChild.setAttribute('value', ''),
            '' === e.firstChild.getAttribute('value')
        }) || o('value', function (e, t, n) {
            if (!n && 'input' === e.nodeName.toLowerCase()) return e.defaultValue
        }),
        i(function (e) {
            return null == e.getAttribute('disabled')
        }) || o(te, function (e, t, n) {
            var r;
            if (!n) return e[t] === !0 ? t.toLowerCase() : (r = e.getAttributeNode(t)) && r.specified ? r.value : null
        }),
            t
    }(e);
    pe.find = ve,
        pe.expr = ve.selectors,
        pe.expr[':'] = pe.expr.pseudos,
        pe.uniqueSort = pe.unique = ve.uniqueSort,
        pe.text = ve.getText,
        pe.isXMLDoc = ve.isXML,
        pe.contains = ve.contains;
    var xe = function (e, t, n) {
            for (var r = [], i = void 0 !== n; (e = e[t]) && 9 !== e.nodeType;) if (1 === e.nodeType) {
                if (i && pe(e).is(n)) break;
                r.push(e)
            }
            return r
        },
        be = function (e, t) {
            for (var n = []; e; e = e.nextSibling) 1 === e.nodeType && e !== t && n.push(e);
            return n
        },
        we = pe.expr.match.needsContext,
        Te = /^<([\w-]+)\s*\/?>(?:<\/\1>|)$/,
        Ce = /^.[^:#\[\.,]*$/;
    pe.filter = function (e, t, n) {
        var r = t[0];
        return n && (e = ':not(' + e + ')'),
            1 === t.length && 1 === r.nodeType ? pe.find.matchesSelector(r, e) ? [
                r
            ] : [] : pe.find.matches(e, pe.grep(t, function (e) {
                return 1 === e.nodeType
            }))
    },
        pe.fn.extend({
            find: function (e) {
                var t,
                    n = [],
                    r = this,
                    i = r.length;
                if ('string' != typeof e) return this.pushStack(pe(e).filter(function () {
                    for (t = 0; t < i; t++) if (pe.contains(r[t], this)) return !0
                }));
                for (t = 0; t < i; t++) pe.find(e, r[t], n);
                return n = this.pushStack(i > 1 ? pe.unique(n) : n),
                    n.selector = this.selector ? this.selector + ' ' + e : e,
                    n
            },
            filter: function (e) {
                return this.pushStack(r(this, e || [], !1))
            },
            not: function (e) {
                return this.pushStack(r(this, e || [], !0))
            },
            is: function (e) {
                return !!r(this, 'string' == typeof e && we.test(e) ? pe(e) : e || [], !1).length
            }
        });
    var Ee,
        Ne = /^(?:\s*(<[\w\W]+>)[^>]*|#([\w-]*))$/,
        ke = pe.fn.init = function (e, t, n) {
            var r,
                i;
            if (!e) return this;
            if (n = n || Ee, 'string' == typeof e) {
                if (r = '<' === e.charAt(0) && '>' === e.charAt(e.length - 1) && e.length >= 3 ? [
                    null,
                    e,
                    null
                ] : Ne.exec(e), !r || !r[1] && t) return !t || t.jquery ? (t || n).find(e) : this.constructor(t).find(e);
                if (r[1]) {
                    if (t = t instanceof pe ? t[0] : t, pe.merge(this, pe.parseHTML(r[1], t && t.nodeType ? t.ownerDocument || t : re, !0)), Te.test(r[1]) && pe.isPlainObject(t)) for (r in t) pe.isFunction(this[r]) ? this[r](t[r]) : this.attr(r, t[r]);
                    return this
                }
                if (i = re.getElementById(r[2]), i && i.parentNode) {
                    if (i.id !== r[2]) return Ee.find(e);
                    this.length = 1,
                        this[0] = i
                }
                return this.context = re,
                    this.selector = e,
                    this
            }
            return e.nodeType ? (this.context = this[0] = e, this.length = 1, this) : pe.isFunction(e) ? 'undefined' != typeof n.ready ? n.ready(e) : e(pe) : (void 0 !== e.selector && (this.selector = e.selector, this.context = e.context), pe.makeArray(e, this))
        };
    ke.prototype = pe.fn,
        Ee = pe(re);
    var Se = /^(?:parents|prev(?:Until|All))/,
        Ae = {
            children: !0,
            contents: !0,
            next: !0,
            prev: !0
        };
    pe.fn.extend({
        has: function (e) {
            var t,
                n = pe(e, this),
                r = n.length;
            return this.filter(function () {
                for (t = 0; t < r; t++) if (pe.contains(this, n[t])) return !0
            })
        },
        closest: function (e, t) {
            for (var n, r = 0, i = this.length, o = [], a = we.test(e) || 'string' != typeof e ? pe(e, t || this.context) : 0; r < i; r++) for (n = this[r]; n && n !== t; n = n.parentNode) if (n.nodeType < 11 && (a ? a.index(n) > -1 : 1 === n.nodeType && pe.find.matchesSelector(n, e))) {
                o.push(n);
                break
            }
            return this.pushStack(o.length > 1 ? pe.uniqueSort(o) : o)
        },
        index: function (e) {
            return e ? 'string' == typeof e ? pe.inArray(this[0], pe(e)) : pe.inArray(e.jquery ? e[0] : e, this) : this[0] && this[0].parentNode ? this.first().prevAll().length : -1
        },
        add: function (e, t) {
            return this.pushStack(pe.uniqueSort(pe.merge(this.get(), pe(e, t))))
        },
        addBack: function (e) {
            return this.add(null == e ? this.prevObject : this.prevObject.filter(e))
        }
    }),
        pe.each({
            parent: function (e) {
                var t = e.parentNode;
                return t && 11 !== t.nodeType ? t : null
            },
            parents: function (e) {
                return xe(e, 'parentNode')
            },
            parentsUntil: function (e, t, n) {
                return xe(e, 'parentNode', n)
            },
            next: function (e) {
                return i(e, 'nextSibling')
            },
            prev: function (e) {
                return i(e, 'previousSibling')
            },
            nextAll: function (e) {
                return xe(e, 'nextSibling')
            },
            prevAll: function (e) {
                return xe(e, 'previousSibling')
            },
            nextUntil: function (e, t, n) {
                return xe(e, 'nextSibling', n)
            },
            prevUntil: function (e, t, n) {
                return xe(e, 'previousSibling', n)
            },
            siblings: function (e) {
                return be((e.parentNode || {}).firstChild, e)
            },
            children: function (e) {
                return be(e.firstChild)
            },
            contents: function (e) {
                return pe.nodeName(e, 'iframe') ? e.contentDocument || e.contentWindow.document : pe.merge([], e.childNodes)
            }
        }, function (e, t) {
            pe.fn[e] = function (n, r) {
                var i = pe.map(this, t, n);
                return 'Until' !== e.slice(-5) && (r = n),
                r && 'string' == typeof r && (i = pe.filter(r, i)),
                this.length > 1 && (Ae[e] || (i = pe.uniqueSort(i)), Se.test(e) && (i = i.reverse())),
                    this.pushStack(i)
            }
        });
    var De = /\S+/g;
    pe.Callbacks = function (e) {
        e = 'string' == typeof e ? o(e) : pe.extend({}, e);
        var t,
            n,
            r,
            i,
            a = [],
            s = [],
            u = -1,
            l = function () {
                for (i = e.once, r = t = !0; s.length; u = -1) for (n = s.shift(); ++u < a.length;) a[u].apply(n[0], n[1]) === !1 && e.stopOnFalse && (u = a.length, n = !1);
                e.memory || (n = !1),
                    t = !1,
                i && (a = n ? [] : '')
            },
            c = {
                add: function () {
                    return a && (n && !t && (u = a.length - 1, s.push(n)), function r(t) {
                        pe.each(t, function (t, n) {
                            pe.isFunction(n) ? e.unique && c.has(n) || a.push(n) : n && n.length && 'string' !== pe.type(n) && r(n)
                        })
                    }(arguments), n && !t && l()),
                        this
                },
                remove: function () {
                    return pe.each(arguments, function (e, t) {
                        for (var n; (n = pe.inArray(t, a, n)) > -1;) a.splice(n, 1),
                        n <= u && u--
                    }),
                        this
                },
                has: function (e) {
                    return e ? pe.inArray(e, a) > -1 : a.length > 0
                },
                empty: function () {
                    return a && (a = []),
                        this
                },
                disable: function () {
                    return i = s = [],
                        a = n = '',
                        this
                },
                disabled: function () {
                    return !a
                },
                lock: function () {
                    return i = !0,
                    n || c.disable(),
                        this
                },
                locked: function () {
                    return !!i
                },
                fireWith: function (e, n) {
                    return i || (n = n || [], n = [
                        e,
                        n.slice ? n.slice() : n
                    ], s.push(n), t || l()),
                        this
                },
                fire: function () {
                    return c.fireWith(this, arguments),
                        this
                },
                fired: function () {
                    return !!r
                }
            };
        return c
    },
        pe.extend({
            Deferred: function (e) {
                var t = [
                        ['resolve',
                            'done',
                            pe.Callbacks('once memory'),
                            'resolved'],
                        [
                            'reject',
                            'fail',
                            pe.Callbacks('once memory'),
                            'rejected'
                        ],
                        [
                            'notify',
                            'progress',
                            pe.Callbacks('memory')
                        ]
                    ],
                    n = 'pending',
                    r = {
                        state: function () {
                            return n
                        },
                        always: function () {
                            return i.done(arguments).fail(arguments),
                                this
                        },
                        then: function () {
                            var e = arguments;
                            return pe.Deferred(function (n) {
                                pe.each(t, function (t, o) {
                                    var a = pe.isFunction(e[t]) && e[t];
                                    i[o[1]](function () {
                                        var e = a && a.apply(this, arguments);
                                        e && pe.isFunction(e.promise) ? e.promise().progress(n.notify).done(n.resolve).fail(n.reject) : n[o[0] + 'With'](this === r ? n.promise() : this, a ? [
                                            e
                                        ] : arguments)
                                    })
                                }),
                                    e = null
                            }).promise()
                        },
                        promise: function (e) {
                            return null != e ? pe.extend(e, r) : r
                        }
                    },
                    i = {};
                return r.pipe = r.then,
                    pe.each(t, function (e, o) {
                        var a = o[2],
                            s = o[3];
                        r[o[1]] = a.add,
                        s && a.add(function () {
                            n = s
                        }, t[1 ^ e][2].disable, t[2][2].lock),
                            i[o[0]] = function () {
                                return i[o[0] + 'With'](this === i ? r : this, arguments),
                                    this
                            },
                            i[o[0] + 'With'] = a.fireWith
                    }),
                    r.promise(i),
                e && e.call(i, i),
                    i
            },
            when: function (e) {
                var t,
                    n,
                    r,
                    i = 0,
                    o = ie.call(arguments),
                    a = o.length,
                    s = 1 !== a || e && pe.isFunction(e.promise) ? a : 0,
                    u = 1 === s ? e : pe.Deferred(),
                    l = function (e, n, r) {
                        return function (i) {
                            n[e] = this,
                                r[e] = arguments.length > 1 ? ie.call(arguments) : i,
                                r === t ? u.notifyWith(n, r) : --s || u.resolveWith(n, r)
                        }
                    };
                if (a > 1) for (t = new Array(a), n = new Array(a), r = new Array(a); i < a; i++) o[i] && pe.isFunction(o[i].promise) ? o[i].promise().progress(l(i, n, t)).done(l(i, r, o)).fail(u.reject) : --s;
                return s || u.resolveWith(r, o),
                    u.promise()
            }
        });
    var je;
    pe.fn.ready = function (e) {
        return pe.ready.promise().done(e),
            this
    },
        pe.extend({
            isReady: !1,
            readyWait: 1,
            holdReady: function (e) {
                e ? pe.readyWait++ : pe.ready(!0)
            },
            ready: function (e) {
                (e === !0 ? --pe.readyWait : pe.isReady) || (pe.isReady = !0, e !== !0 && --pe.readyWait > 0 || (je.resolveWith(re, [
                    pe
                ]), pe.fn.triggerHandler && (pe(re).triggerHandler('ready'), pe(re).off('ready'))))
            }
        }),
        pe.ready.promise = function (t) {
            if (!je) if (je = pe.Deferred(), 'complete' === re.readyState || 'loading' !== re.readyState && !re.documentElement.doScroll) e.setTimeout(pe.ready);
            else if (re.addEventListener) re.addEventListener('DOMContentLoaded', s),
                e.addEventListener('load', s);
            else {
                re.attachEvent('onreadystatechange', s),
                    e.attachEvent('onload', s);
                var n = !1;
                try {
                    n = null == e.frameElement && re.documentElement
                } catch (r) {
                }
                n && n.doScroll && !function i() {
                    if (!pe.isReady) {
                        try {
                            n.doScroll('left')
                        } catch (t) {
                            return e.setTimeout(i, 50)
                        }
                        a(),
                            pe.ready()
                    }
                }()
            }
            return je.promise(t)
        },
        pe.ready.promise();
    var Le;
    for (Le in pe(fe)) break;
    fe.ownFirst = '0' === Le,
        fe.inlineBlockNeedsLayout = !1,
        pe(function () {
            var e,
                t,
                n,
                r;
            n = re.getElementsByTagName('body') [0],
            n && n.style && (t = re.createElement('div'), r = re.createElement('div'), r.style.cssText = 'position:absolute;border:0;width:0;height:0;top:0;left:-9999px', n.appendChild(r).appendChild(t), 'undefined' != typeof t.style.zoom && (t.style.cssText = 'display:inline;margin:0;border:0;padding:1px;width:1px;zoom:1', fe.inlineBlockNeedsLayout = e = 3 === t.offsetWidth, e && (n.style.zoom = 1)), n.removeChild(r))
        }),
        function () {
            var e = re.createElement('div');
            fe.deleteExpando = !0;
            try {
                delete e.test
            } catch (t) {
                fe.deleteExpando = !1
            }
            e = null
        }();
    var He = function (e) {
            var t = pe.noData[(e.nodeName + ' ').toLowerCase()],
                n = +e.nodeType || 1;
            return (1 === n || 9 === n) && (!t || t !== !0 && e.getAttribute('classid') === t)
        },
        qe = /^(?:\{[\w\W]*\}|\[[\w\W]*\])$/,
        _e = /([A-Z])/g;
    pe.extend({
        cache: {},
        noData: {
            'applet ': !0,
            'embed ': !0,
            'object ': 'clsid:D27CDB6E-AE6D-11cf-96B8-444553540000'
        },
        hasData: function (e) {
            return e = e.nodeType ? pe.cache[e[pe.expando]] : e[pe.expando],
            !!e && !l(e)
        },
        data: function (e, t, n) {
            return c(e, t, n)
        },
        removeData: function (e, t) {
            return f(e, t)
        },
        _data: function (e, t, n) {
            return c(e, t, n, !0)
        },
        _removeData: function (e, t) {
            return f(e, t, !0)
        }
    }),
        pe.fn.extend({
            data: function (e, t) {
                var n,
                    r,
                    i,
                    o = this[0],
                    a = o && o.attributes;
                if (void 0 === e) {
                    if (this.length && (i = pe.data(o), 1 === o.nodeType && !pe._data(o, 'parsedAttrs'))) {
                        for (n = a.length; n--;) a[n] && (r = a[n].name, 0 === r.indexOf('data-') && (r = pe.camelCase(r.slice(5)), u(o, r, i[r])));
                        pe._data(o, 'parsedAttrs', !0)
                    }
                    return i
                }
                return 'object' == typeof e ? this.each(function () {
                    pe.data(this, e)
                }) : arguments.length > 1 ? this.each(function () {
                    pe.data(this, e, t)
                }) : o ? u(o, e, pe.data(o, e)) : void 0
            },
            removeData: function (e) {
                return this.each(function () {
                    pe.removeData(this, e)
                })
            }
        }),
        pe.extend({
            queue: function (e, t, n) {
                var r;
                if (e) return t = (t || 'fx') + 'queue',
                    r = pe._data(e, t),
                n && (!r || pe.isArray(n) ? r = pe._data(e, t, pe.makeArray(n)) : r.push(n)),
                r || []
            },
            dequeue: function (e, t) {
                t = t || 'fx';
                var n = pe.queue(e, t),
                    r = n.length,
                    i = n.shift(),
                    o = pe._queueHooks(e, t),
                    a = function () {
                        pe.dequeue(e, t)
                    };
                'inprogress' === i && (i = n.shift(), r--),
                i && ('fx' === t && n.unshift('inprogress'), delete o.stop, i.call(e, a, o)),
                !r && o && o.empty.fire()
            },
            _queueHooks: function (e, t) {
                var n = t + 'queueHooks';
                return pe._data(e, n) || pe._data(e, n, {
                    empty: pe.Callbacks('once memory').add(function () {
                        pe._removeData(e, t + 'queue'),
                            pe._removeData(e, n)
                    })
                })
            }
        }),
        pe.fn.extend({
            queue: function (e, t) {
                var n = 2;
                return 'string' != typeof e && (t = e, e = 'fx', n--),
                    arguments.length < n ? pe.queue(this[0], e) : void 0 === t ? this : this.each(function () {
                        var n = pe.queue(this, e, t);
                        pe._queueHooks(this, e),
                        'fx' === e && 'inprogress' !== n[0] && pe.dequeue(this, e)
                    })
            },
            dequeue: function (e) {
                return this.each(function () {
                    pe.dequeue(this, e)
                })
            },
            clearQueue: function (e) {
                return this.queue(e || 'fx', [])
            },
            promise: function (e, t) {
                var n,
                    r = 1,
                    i = pe.Deferred(),
                    o = this,
                    a = this.length,
                    s = function () {
                        --r || i.resolveWith(o, [
                            o
                        ])
                    };
                for ('string' != typeof e && (t = e, e = void 0), e = e || 'fx'; a--;) n = pe._data(o[a], e + 'queueHooks'),
                n && n.empty && (r++, n.empty.add(s));
                return s(),
                    i.promise(t)
            }
        }),
        function () {
            var e;
            fe.shrinkWrapBlocks = function () {
                if (null != e) return e;
                e = !1;
                var t,
                    n,
                    r;
                return n = re.getElementsByTagName('body') [0],
                    n && n.style ? (t = re.createElement('div'), r = re.createElement('div'), r.style.cssText = 'position:absolute;border:0;width:0;height:0;top:0;left:-9999px', n.appendChild(r).appendChild(t), 'undefined' != typeof t.style.zoom && (t.style.cssText = '-webkit-box-sizing:content-box;-moz-box-sizing:content-box;box-sizing:content-box;display:block;margin:0;border:0;padding:1px;width:1px;zoom:1', t.appendChild(re.createElement('div')).style.width = '5px', e = 3 !== t.offsetWidth), n.removeChild(r), e) : void 0
            }
        }();
    var Fe = /[+-]?(?:\d*\.|)\d+(?:[eE][+-]?\d+|)/.source,
        Me = new RegExp('^(?:([+-])=|)(' + Fe + ')([a-z%]*)$', 'i'),
        Oe = [
            'Top',
            'Right',
            'Bottom',
            'Left'
        ],
        Re = function (e, t) {
            return e = t || e,
            'none' === pe.css(e, 'display') || !pe.contains(e.ownerDocument, e)
        },
        Pe = function (e, t, n, r, i, o, a) {
            var s = 0,
                u = e.length,
                l = null == n;
            if ('object' === pe.type(n)) {
                i = !0;
                for (s in n) Pe(e, t, s, n[s], !0, o, a)
            } else if (void 0 !== r && (i = !0, pe.isFunction(r) || (a = !0), l && (a ? (t.call(e, r), t = null) : (l = t, t = function (e, t, n) {
                return l.call(pe(e), n)
            })), t)) for (; s < u; s++) t(e[s], n, a ? r : r.call(e[s], s, t(e[s], n)));
            return i ? e : l ? t.call(e) : u ? t(e[0], n) : o
        },
        Be = /^(?:checkbox|radio)$/i,
        We = /<([\w:-]+)/,
        Ie = /^$|\/(?:java|ecma)script/i,
        $e = /^\s+/,
        ze = 'abbr|article|aside|audio|bdi|canvas|data|datalist|details|dialog|figcaption|figure|footer|header|hgroup|main|mark|meter|nav|output|picture|progress|section|summary|template|time|video';
    !function () {
        var e = re.createElement('div'),
            t = re.createDocumentFragment(),
            n = re.createElement('input');
        e.innerHTML = '  <link/><table></table><a href=\'/a\'>a</a><input type=\'checkbox\'/>',
            fe.leadingWhitespace = 3 === e.firstChild.nodeType,
            fe.tbody = !e.getElementsByTagName('tbody').length,
            fe.htmlSerialize = !!e.getElementsByTagName('link').length,
            fe.html5Clone = '<:nav></:nav>' !== re.createElement('nav').cloneNode(!0).outerHTML,
            n.type = 'checkbox',
            n.checked = !0,
            t.appendChild(n),
            fe.appendChecked = n.checked,
            e.innerHTML = '<textarea>x</textarea>',
            fe.noCloneChecked = !!e.cloneNode(!0).lastChild.defaultValue,
            t.appendChild(e),
            n = re.createElement('input'),
            n.setAttribute('type', 'radio'),
            n.setAttribute('checked', 'checked'),
            n.setAttribute('name', 't'),
            e.appendChild(n),
            fe.checkClone = e.cloneNode(!0).cloneNode(!0).lastChild.checked,
            fe.noCloneEvent = !!e.addEventListener,
            e[pe.expando] = 1,
            fe.attributes = !e.getAttribute(pe.expando)
    }();
    var Xe = {
        option: [
            1,
            '<select multiple=\'multiple\'>',
            '</select>'
        ],
        legend: [
            1,
            '<fieldset>',
            '</fieldset>'
        ],
        area: [
            1,
            '<map>',
            '</map>'
        ],
        param: [
            1,
            '<object>',
            '</object>'
        ],
        thead: [
            1,
            '<table>',
            '</table>'
        ],
        tr: [
            2,
            '<table><tbody>',
            '</tbody></table>'
        ],
        col: [
            2,
            '<table><tbody></tbody><colgroup>',
            '</colgroup></table>'
        ],
        td: [
            3,
            '<table><tbody><tr>',
            '</tr></tbody></table>'
        ],
        _default: fe.htmlSerialize ? [
            0,
            '',
            ''
        ] : [
            1,
            'X<div>',
            '</div>'
        ]
    };
    Xe.optgroup = Xe.option,
        Xe.tbody = Xe.tfoot = Xe.colgroup = Xe.caption = Xe.thead,
        Xe.th = Xe.td;
    var Ue = /<|&#?\w+;/,
        Ve = /<tbody/i;
    !function () {
        var t,
            n,
            r = re.createElement('div');
        for (t in {
            submit: !0,
            change: !0,
            focusin: !0
        }) n = 'on' + t,
        (fe[t] = n in e) || (r.setAttribute(n, 't'), fe[t] = r.attributes[n].expando === !1);
        r = null
    }();
    var Ye = /^(?:input|select|textarea)$/i,
        Je = /^key/,
        Ge = /^(?:mouse|pointer|contextmenu|drag|drop)|click/,
        Ke = /^(?:focusinfocus|focusoutblur)$/,
        Qe = /^([^.]*)(?:\.(.+)|)/;
    pe.event = {
        global: {},
        add: function (e, t, n, r, i) {
            var o,
                a,
                s,
                u,
                l,
                c,
                f,
                d,
                p,
                h,
                g,
                m = pe._data(e);
            if (m) {
                for (n.handler && (u = n, n = u.handler, i = u.selector), n.guid || (n.guid = pe.guid++), (a = m.events) || (a = m.events = {}), (c = m.handle) || (c = m.handle = function (e) {
                    return 'undefined' == typeof pe || e && pe.event.triggered === e.type ? void 0 : pe.event.dispatch.apply(c.elem, arguments)
                }, c.elem = e), t = (t || '').match(De) || [
                    ''
                ], s = t.length; s--;) o = Qe.exec(t[s]) || [],
                    p = g = o[1],
                    h = (o[2] || '').split('.').sort(),
                p && (l = pe.event.special[p] || {}, p = (i ? l.delegateType : l.bindType) || p, l = pe.event.special[p] || {}, f = pe.extend({
                    type: p,
                    origType: g,
                    data: r,
                    handler: n,
                    guid: n.guid,
                    selector: i,
                    needsContext: i && pe.expr.match.needsContext.test(i),
                    namespace: h.join('.')
                }, u), (d = a[p]) || (d = a[p] = [], d.delegateCount = 0, l.setup && l.setup.call(e, r, h, c) !== !1 || (e.addEventListener ? e.addEventListener(p, c, !1) : e.attachEvent && e.attachEvent('on' + p, c))), l.add && (l.add.call(e, f), f.handler.guid || (f.handler.guid = n.guid)), i ? d.splice(d.delegateCount++, 0, f) : d.push(f), pe.event.global[p] = !0);
                e = null
            }
        },
        remove: function (e, t, n, r, i) {
            var o,
                a,
                s,
                u,
                l,
                c,
                f,
                d,
                p,
                h,
                g,
                m = pe.hasData(e) && pe._data(e);
            if (m && (c = m.events)) {
                for (t = (t || '').match(De) || [
                    ''
                ], l = t.length; l--;) if (s = Qe.exec(t[l]) || [], p = g = s[1], h = (s[2] || '').split('.').sort(), p) {
                    for (f = pe.event.special[p] || {}, p = (r ? f.delegateType : f.bindType) || p, d = c[p] || [], s = s[2] && new RegExp('(^|\\.)' + h.join('\\.(?:.*\\.|)') + '(\\.|$)'), u = o = d.length; o--;) a = d[o],
                    !i && g !== a.origType || n && n.guid !== a.guid || s && !s.test(a.namespace) || r && r !== a.selector && ('**' !== r || !a.selector) || (d.splice(o, 1), a.selector && d.delegateCount--, f.remove && f.remove.call(e, a));
                    u && !d.length && (f.teardown && f.teardown.call(e, h, m.handle) !== !1 || pe.removeEvent(e, p, m.handle), delete c[p])
                } else for (p in c) pe.event.remove(e, p + t[l], n, r, !0);
                pe.isEmptyObject(c) && (delete m.handle, pe._removeData(e, 'events'))
            }
        },
        trigger: function (t, n, r, i) {
            var o,
                a,
                s,
                u,
                l,
                c,
                f,
                d = [
                    r || re
                ],
                p = ce.call(t, 'type') ? t.type : t,
                h = ce.call(t, 'namespace') ? t.namespace.split('.') : [];
            if (s = c = r = r || re, 3 !== r.nodeType && 8 !== r.nodeType && !Ke.test(p + pe.event.triggered) && (p.indexOf('.') > -1 && (h = p.split('.'), p = h.shift(), h.sort()), a = p.indexOf(':') < 0 && 'on' + p, t = t[pe.expando] ? t : new pe.Event(p, 'object' == typeof t && t), t.isTrigger = i ? 2 : 3, t.namespace = h.join('.'), t.rnamespace = t.namespace ? new RegExp('(^|\\.)' + h.join('\\.(?:.*\\.|)') + '(\\.|$)') : null, t.result = void 0, t.target || (t.target = r), n = null == n ? [
                t
            ] : pe.makeArray(n, [
                t
            ]), l = pe.event.special[p] || {}, i || !l.trigger || l.trigger.apply(r, n) !== !1)) {
                if (!i && !l.noBubble && !pe.isWindow(r)) {
                    for (u = l.delegateType || p, Ke.test(u + p) || (s = s.parentNode); s; s = s.parentNode) d.push(s),
                        c = s;
                    c === (r.ownerDocument || re) && d.push(c.defaultView || c.parentWindow || e)
                }
                for (f = 0; (s = d[f++]) && !t.isPropagationStopped();) t.type = f > 1 ? u : l.bindType || p,
                    o = (pe._data(s, 'events') || {}) [t.type] && pe._data(s, 'handle'),
                o && o.apply(s, n),
                    o = a && s[a],
                o && o.apply && He(s) && (t.result = o.apply(s, n), t.result === !1 && t.preventDefault());
                if (t.type = p, !i && !t.isDefaultPrevented() && (!l._default || l._default.apply(d.pop(), n) === !1) && He(r) && a && r[p] && !pe.isWindow(r)) {
                    c = r[a],
                    c && (r[a] = null),
                        pe.event.triggered = p;
                    try {
                        r[p]()
                    } catch (g) {
                    }
                    pe.event.triggered = void 0,
                    c && (r[a] = c)
                }
                return t.result
            }
        },
        dispatch: function (e) {
            e = pe.event.fix(e);
            var t,
                n,
                r,
                i,
                o,
                a = [],
                s = ie.call(arguments),
                u = (pe._data(this, 'events') || {}) [e.type] || [],
                l = pe.event.special[e.type] || {};
            if (s[0] = e, e.delegateTarget = this, !l.preDispatch || l.preDispatch.call(this, e) !== !1) {
                for (a = pe.event.handlers.call(this, e, u), t = 0; (i = a[t++]) && !e.isPropagationStopped();) for (e.currentTarget = i.elem, n = 0; (o = i.handlers[n++]) && !e.isImmediatePropagationStopped();) e.rnamespace && !e.rnamespace.test(o.namespace) || (e.handleObj = o, e.data = o.data, r = ((pe.event.special[o.origType] || {}).handle || o.handler).apply(i.elem, s), void 0 !== r && (e.result = r) === !1 && (e.preventDefault(), e.stopPropagation()));
                return l.postDispatch && l.postDispatch.call(this, e),
                    e.result
            }
        },
        handlers: function (e, t) {
            var n,
                r,
                i,
                o,
                a = [],
                s = t.delegateCount,
                u = e.target;
            if (s && u.nodeType && ('click' !== e.type || isNaN(e.button) || e.button < 1)) for (; u != this; u = u.parentNode || this) if (1 === u.nodeType && (u.disabled !== !0 || 'click' !== e.type)) {
                for (r = [], n = 0; n < s; n++) o = t[n],
                    i = o.selector + ' ',
                void 0 === r[i] && (r[i] = o.needsContext ? pe(i, this).index(u) > -1 : pe.find(i, this, null, [
                    u
                ]).length),
                r[i] && r.push(o);
                r.length && a.push({
                    elem: u,
                    handlers: r
                })
            }
            return s < t.length && a.push({
                elem: this,
                handlers: t.slice(s)
            }),
                a
        },
        fix: function (e) {
            if (e[pe.expando]) return e;
            var t,
                n,
                r,
                i = e.type,
                o = e,
                a = this.fixHooks[i];
            for (a || (this.fixHooks[i] = a = Ge.test(i) ? this.mouseHooks : Je.test(i) ? this.keyHooks : {}), r = a.props ? this.props.concat(a.props) : this.props, e = new pe.Event(o), t = r.length; t--;) n = r[t],
                e[n] = o[n];
            return e.target || (e.target = o.srcElement || re),
            3 === e.target.nodeType && (e.target = e.target.parentNode),
                e.metaKey = !!e.metaKey,
                a.filter ? a.filter(e, o) : e
        },
        props: 'altKey bubbles cancelable ctrlKey currentTarget detail eventPhase metaKey relatedTarget shiftKey target timeStamp view which'.split(' '),
        fixHooks: {},
        keyHooks: {
            props: 'char charCode key keyCode'.split(' '),
            filter: function (e, t) {
                return null == e.which && (e.which = null != t.charCode ? t.charCode : t.keyCode),
                    e
            }
        },
        mouseHooks: {
            props: 'button buttons clientX clientY fromElement offsetX offsetY pageX pageY screenX screenY toElement'.split(' '),
            filter: function (e, t) {
                var n,
                    r,
                    i,
                    o = t.button,
                    a = t.fromElement;
                return null == e.pageX && null != t.clientX && (r = e.target.ownerDocument || re, i = r.documentElement, n = r.body, e.pageX = t.clientX + (i && i.scrollLeft || n && n.scrollLeft || 0) - (i && i.clientLeft || n && n.clientLeft || 0), e.pageY = t.clientY + (i && i.scrollTop || n && n.scrollTop || 0) - (i && i.clientTop || n && n.clientTop || 0)),
                !e.relatedTarget && a && (e.relatedTarget = a === e.target ? t.toElement : a),
                e.which || void 0 === o || (e.which = 1 & o ? 1 : 2 & o ? 3 : 4 & o ? 2 : 0),
                    e
            }
        },
        special: {
            load: {
                noBubble: !0
            },
            focus: {
                trigger: function () {
                    if (this !== b() && this.focus) try {
                        return this.focus(),
                            !1
                    } catch (e) {
                    }
                },
                delegateType: 'focusin'
            },
            blur: {
                trigger: function () {
                    if (this === b() && this.blur) return this.blur(),
                        !1
                },
                delegateType: 'focusout'
            },
            click: {
                trigger: function () {
                    if (pe.nodeName(this, 'input') && 'checkbox' === this.type && this.click) return this.click(),
                        !1
                },
                _default: function (e) {
                    return pe.nodeName(e.target, 'a')
                }
            },
            beforeunload: {
                postDispatch: function (e) {
                    void 0 !== e.result && e.originalEvent && (e.originalEvent.returnValue = e.result)
                }
            }
        },
        simulate: function (e, t, n) {
            var r = pe.extend(new pe.Event, n, {
                type: e,
                isSimulated: !0
            });
            pe.event.trigger(r, null, t),
            r.isDefaultPrevented() && n.preventDefault()
        }
    },
        pe.removeEvent = re.removeEventListener ? function (e, t, n) {
                e.removeEventListener && e.removeEventListener(t, n)
            }
            : function (e, t, n) {
                var r = 'on' + t;
                e.detachEvent && ('undefined' == typeof e[r] && (e[r] = null), e.detachEvent(r, n))
            },
        pe.Event = function (e, t) {
            return this instanceof pe.Event ? (e && e.type ? (this.originalEvent = e, this.type = e.type, this.isDefaultPrevented = e.defaultPrevented || void 0 === e.defaultPrevented && e.returnValue === !1 ? v : x) : this.type = e, t && pe.extend(this, t), this.timeStamp = e && e.timeStamp || pe.now(), void (this[pe.expando] = !0)) : new pe.Event(e, t)
        },
        pe.Event.prototype = {
            constructor: pe.Event,
            isDefaultPrevented: x,
            isPropagationStopped: x,
            isImmediatePropagationStopped: x,
            preventDefault: function () {
                var e = this.originalEvent;
                this.isDefaultPrevented = v,
                e && (e.preventDefault ? e.preventDefault() : e.returnValue = !1)
            },
            stopPropagation: function () {
                var e = this.originalEvent;
                this.isPropagationStopped = v,
                e && !this.isSimulated && (e.stopPropagation && e.stopPropagation(), e.cancelBubble = !0)
            },
            stopImmediatePropagation: function () {
                var e = this.originalEvent;
                this.isImmediatePropagationStopped = v,
                e && e.stopImmediatePropagation && e.stopImmediatePropagation(),
                    this.stopPropagation()
            }
        },
        pe.each({
            mouseenter: 'mouseover',
            mouseleave: 'mouseout',
            pointerenter: 'pointerover',
            pointerleave: 'pointerout'
        }, function (e, t) {
            pe.event.special[e] = {
                delegateType: t,
                bindType: t,
                handle: function (e) {
                    var n,
                        r = this,
                        i = e.relatedTarget,
                        o = e.handleObj;
                    return i && (i === r || pe.contains(r, i)) || (e.type = o.origType, n = o.handler.apply(this, arguments), e.type = t),
                        n
                }
            }
        }),
    fe.submit || (pe.event.special.submit = {
        setup: function () {
            return !pe.nodeName(this, 'form') && void pe.event.add(this, 'click._submit keypress._submit', function (e) {
                var t = e.target,
                    n = pe.nodeName(t, 'input') || pe.nodeName(t, 'button') ? pe.prop(t, 'form') : void 0;
                n && !pe._data(n, 'submit') && (pe.event.add(n, 'submit._submit', function (e) {
                    e._submitBubble = !0
                }), pe._data(n, 'submit', !0))
            })
        },
        postDispatch: function (e) {
            e._submitBubble && (delete e._submitBubble, this.parentNode && !e.isTrigger && pe.event.simulate('submit', this.parentNode, e))
        },
        teardown: function () {
            return !pe.nodeName(this, 'form') && void pe.event.remove(this, '._submit')
        }
    }),
    fe.change || (pe.event.special.change = {
        setup: function () {
            return Ye.test(this.nodeName) ? ('checkbox' !== this.type && 'radio' !== this.type || (pe.event.add(this, 'propertychange._change', function (e) {
                'checked' === e.originalEvent.propertyName && (this._justChanged = !0)
            }), pe.event.add(this, 'click._change', function (e) {
                this._justChanged && !e.isTrigger && (this._justChanged = !1),
                    pe.event.simulate('change', this, e)
            })), !1) : void pe.event.add(this, 'beforeactivate._change', function (e) {
                var t = e.target;
                Ye.test(t.nodeName) && !pe._data(t, 'change') && (pe.event.add(t, 'change._change', function (e) {
                    !this.parentNode || e.isSimulated || e.isTrigger || pe.event.simulate('change', this.parentNode, e)
                }), pe._data(t, 'change', !0))
            })
        },
        handle: function (e) {
            var t = e.target;
            if (this !== t || e.isSimulated || e.isTrigger || 'radio' !== t.type && 'checkbox' !== t.type) return e.handleObj.handler.apply(this, arguments)
        },
        teardown: function () {
            return pe.event.remove(this, '._change'),
                !Ye.test(this.nodeName)
        }
    }),
    fe.focusin || pe.each({
        focus: 'focusin',
        blur: 'focusout'
    }, function (e, t) {
        var n = function (e) {
            pe.event.simulate(t, e.target, pe.event.fix(e))
        };
        pe.event.special[t] = {
            setup: function () {
                var r = this.ownerDocument || this,
                    i = pe._data(r, t);
                i || r.addEventListener(e, n, !0),
                    pe._data(r, t, (i || 0) + 1)
            },
            teardown: function () {
                var r = this.ownerDocument || this,
                    i = pe._data(r, t) - 1;
                i ? pe._data(r, t, i) : (r.removeEventListener(e, n, !0), pe._removeData(r, t))
            }
        }
    }),
        pe.fn.extend({
            on: function (e, t, n, r) {
                return w(this, e, t, n, r)
            },
            one: function (e, t, n, r) {
                return w(this, e, t, n, r, 1)
            },
            off: function (e, t, n) {
                var r,
                    i;
                if (e && e.preventDefault && e.handleObj) return r = e.handleObj,
                    pe(e.delegateTarget).off(r.namespace ? r.origType + '.' + r.namespace : r.origType, r.selector, r.handler),
                    this;
                if ('object' == typeof e) {
                    for (i in e) this.off(i, t, e[i]);
                    return this
                }
                return t !== !1 && 'function' != typeof t || (n = t, t = void 0),
                n === !1 && (n = x),
                    this.each(function () {
                        pe.event.remove(this, e, n, t)
                    })
            },
            trigger: function (e, t) {
                return this.each(function () {
                    pe.event.trigger(e, t, this)
                })
            },
            triggerHandler: function (e, t) {
                var n = this[0];
                if (n) return pe.event.trigger(e, t, n, !0)
            }
        });
    var Ze = / jQuery\d+="(?:null|\d+)"/g,
        et = new RegExp('<(?:' + ze + ')[\\s/>]', 'i'),
        tt = /<(?!area|br|col|embed|hr|img|input|link|meta|param)(([\w:-]+)[^>]*)\/>/gi,
        nt = /<script|<style|<link/i,
        rt = /checked\s*(?:[^=]|=\s*.checked.)/i,
        it = /^true\/(.*)/,
        ot = /^\s*<!(?:\[CDATA\[|--)|(?:\]\]|--)>\s*$/g,
        at = p(re),
        st = at.appendChild(re.createElement('div'));
    pe.extend({
        htmlPrefilter: function (e) {
            return e.replace(tt, '<$1></$2>')
        },
        clone: function (e, t, n) {
            var r,
                i,
                o,
                a,
                s,
                u = pe.contains(e.ownerDocument, e);
            if (fe.html5Clone || pe.isXMLDoc(e) || !et.test('<' + e.nodeName + '>') ? o = e.cloneNode(!0) : (st.innerHTML = e.outerHTML, st.removeChild(o = st.firstChild)), !(fe.noCloneEvent && fe.noCloneChecked || 1 !== e.nodeType && 11 !== e.nodeType || pe.isXMLDoc(e))) for (r = h(o), s = h(e), a = 0; null != (i = s[a]); ++a) r[a] && k(i, r[a]);
            if (t) if (n) for (s = s || h(e), r = r || h(o), a = 0; null != (i = s[a]); a++) N(i, r[a]);
            else N(e, o);
            return r = h(o, 'script'),
            r.length > 0 && g(r, !u && h(e, 'script')),
                r = s = i = null,
                o
        },
        cleanData: function (e, t) {
            for (var n, r, i, o, a = 0, s = pe.expando, u = pe.cache, l = fe.attributes, c = pe.event.special; null != (n = e[a]); a++) if ((t || He(n)) && (i = n[s], o = i && u[i])) {
                if (o.events) for (r in o.events) c[r] ? pe.event.remove(n, r) : pe.removeEvent(n, r, o.handle);
                u[i] && (delete u[i], l || 'undefined' == typeof n.removeAttribute ? n[s] = void 0 : n.removeAttribute(s), ne.push(i))
            }
        }
    }),
        pe.fn.extend({
            domManip: S,
            detach: function (e) {
                return A(this, e, !0)
            },
            remove: function (e) {
                return A(this, e)
            },
            text: function (e) {
                return Pe(this, function (e) {
                    return void 0 === e ? pe.text(this) : this.empty().append((this[0] && this[0].ownerDocument || re).createTextNode(e))
                }, null, e, arguments.length)
            },
            append: function () {
                return S(this, arguments, function (e) {
                    if (1 === this.nodeType || 11 === this.nodeType || 9 === this.nodeType) {
                        var t = T(this, e);
                        t.appendChild(e)
                    }
                })
            },
            prepend: function () {
                return S(this, arguments, function (e) {
                    if (1 === this.nodeType || 11 === this.nodeType || 9 === this.nodeType) {
                        var t = T(this, e);
                        t.insertBefore(e, t.firstChild)
                    }
                })
            },
            before: function () {
                return S(this, arguments, function (e) {
                    this.parentNode && this.parentNode.insertBefore(e, this)
                })
            },
            after: function () {
                return S(this, arguments, function (e) {
                    this.parentNode && this.parentNode.insertBefore(e, this.nextSibling)
                })
            },
            empty: function () {
                for (var e, t = 0; null != (e = this[t]); t++) {
                    for (1 === e.nodeType && pe.cleanData(h(e, !1)); e.firstChild;) e.removeChild(e.firstChild);
                    e.options && pe.nodeName(e, 'select') && (e.options.length = 0)
                }
                return this
            },
            clone: function (e, t) {
                return e = null != e && e,
                    t = null == t ? e : t,
                    this.map(function () {
                        return pe.clone(this, e, t)
                    })
            },
            html: function (e) {
                return Pe(this, function (e) {
                    var t = this[0] || {},
                        n = 0,
                        r = this.length;
                    if (void 0 === e) return 1 === t.nodeType ? t.innerHTML.replace(Ze, '') : void 0;
                    if ('string' == typeof e && !nt.test(e) && (fe.htmlSerialize || !et.test(e)) && (fe.leadingWhitespace || !$e.test(e)) && !Xe[(We.exec(e) || [
                        '',
                        ''
                    ]) [1].toLowerCase()]) {
                        e = pe.htmlPrefilter(e);
                        try {
                            for (; n < r; n++) t = this[n] || {},
                            1 === t.nodeType && (pe.cleanData(h(t, !1)), t.innerHTML = e);
                            t = 0
                        } catch (i) {
                        }
                    }
                    t && this.empty().append(e)
                }, null, e, arguments.length)
            },
            replaceWith: function () {
                var e = [];
                return S(this, arguments, function (t) {
                    var n = this.parentNode;
                    pe.inArray(this, e) < 0 && (pe.cleanData(h(this)), n && n.replaceChild(t, this))
                }, e)
            }
        }),
        pe.each({
            appendTo: 'append',
            prependTo: 'prepend',
            insertBefore: 'before',
            insertAfter: 'after',
            replaceAll: 'replaceWith'
        }, function (e, t) {
            pe.fn[e] = function (e) {
                for (var n, r = 0, i = [], o = pe(e), a = o.length - 1; r <= a; r++) n = r === a ? this : this.clone(!0),
                    pe(o[r]) [t](n),
                    ae.apply(i, n.get());
                return this.pushStack(i)
            }
        });
    var ut,
        lt = {
            HTML: 'block',
            BODY: 'block'
        },
        ct = /^margin/,
        ft = new RegExp('^(' + Fe + ')(?!px)[a-z%]+$', 'i'),
        dt = function (e, t, n, r) {
            var i,
                o,
                a = {};
            for (o in t) a[o] = e.style[o],
                e.style[o] = t[o];
            i = n.apply(e, r || []);
            for (o in t) e.style[o] = a[o];
            return i
        },
        pt = re.documentElement;
    !function () {
        function t() {
            var t,
                c,
                f = re.documentElement;
            f.appendChild(u),
                l.style.cssText = '-webkit-box-sizing:border-box;box-sizing:border-box;position:relative;display:block;margin:auto;border:1px;padding:1px;top:1%;width:50%',
                n = i = s = !1,
                r = a = !0,
            e.getComputedStyle && (c = e.getComputedStyle(l), n = '1%' !== (c || {}).top, s = '2px' === (c || {}).marginLeft, i = '4px' === (c || {
                width: '4px'
            }).width, l.style.marginRight = '50%', r = '4px' === (c || {
                marginRight: '4px'
            }).marginRight, t = l.appendChild(re.createElement('div')), t.style.cssText = l.style.cssText = '-webkit-box-sizing:content-box;-moz-box-sizing:content-box;box-sizing:content-box;display:block;margin:0;border:0;padding:0', t.style.marginRight = t.style.width = '0', l.style.width = '1px', a = !parseFloat((e.getComputedStyle(t) || {}).marginRight), l.removeChild(t)),
                l.style.display = 'none',
                o = 0 === l.getClientRects().length,
            o && (l.style.display = '', l.innerHTML = '<table><tr><td></td><td>t</td></tr></table>', t = l.getElementsByTagName('td'), t[0].style.cssText = 'margin:0;border:0;padding:0;display:none', o = 0 === t[0].offsetHeight, o && (t[0].style.display = '', t[1].style.display = 'none', o = 0 === t[0].offsetHeight)),
                f.removeChild(u)
        }

        var n,
            r,
            i,
            o,
            a,
            s,
            u = re.createElement('div'),
            l = re.createElement('div');
        l.style && (l.style.cssText = 'float:left;opacity:.5', fe.opacity = '0.5' === l.style.opacity, fe.cssFloat = !!l.style.cssFloat, l.style.backgroundClip = 'content-box', l.cloneNode(!0).style.backgroundClip = '', fe.clearCloneStyle = 'content-box' === l.style.backgroundClip, u = re.createElement('div'), u.style.cssText = 'border:0;width:8px;height:0;top:0;left:-9999px;padding:0;margin-top:1px;position:absolute', l.innerHTML = '', u.appendChild(l), fe.boxSizing = '' === l.style.boxSizing || '' === l.style.MozBoxSizing || '' === l.style.WebkitBoxSizing, pe.extend(fe, {
            reliableHiddenOffsets: function () {
                return null == n && t(),
                    o
            },
            boxSizingReliable: function () {
                return null == n && t(),
                    i
            },
            pixelMarginRight: function () {
                return null == n && t(),
                    r
            },
            pixelPosition: function () {
                return null == n && t(),
                    n
            },
            reliableMarginRight: function () {
                return null == n && t(),
                    a
            },
            reliableMarginLeft: function () {
                return null == n && t(),
                    s
            }
        }))
    }();
    var ht,
        gt,
        mt = /^(top|right|bottom|left)$/;
    e.getComputedStyle ? (ht = function (t) {
        var n = t.ownerDocument.defaultView;
        return n && n.opener || (n = e),
            n.getComputedStyle(t)
    }, gt = function (e, t, n) {
        var r,
            i,
            o,
            a,
            s = e.style;
        return n = n || ht(e),
            a = n ? n.getPropertyValue(t) || n[t] : void 0,
        '' !== a && void 0 !== a || pe.contains(e.ownerDocument, e) || (a = pe.style(e, t)),
        n && !fe.pixelMarginRight() && ft.test(a) && ct.test(t) && (r = s.width, i = s.minWidth, o = s.maxWidth, s.minWidth = s.maxWidth = s.width = a, a = n.width, s.width = r, s.minWidth = i, s.maxWidth = o),
            void 0 === a ? a : a + ''
    }) : pt.currentStyle && (ht = function (e) {
        return e.currentStyle
    }, gt = function (e, t, n) {
        var r,
            i,
            o,
            a,
            s = e.style;
        return n = n || ht(e),
            a = n ? n[t] : void 0,
        null == a && s && s[t] && (a = s[t]),
        ft.test(a) && !mt.test(t) && (r = s.left, i = e.runtimeStyle, o = i && i.left, o && (i.left = e.currentStyle.left), s.left = 'fontSize' === t ? '1em' : a, a = s.pixelLeft + 'px', s.left = r, o && (i.left = o)),
            void 0 === a ? a : a + '' || 'auto'
    });
    var yt = /alpha\([^)]*\)/i,
        vt = /opacity\s*=\s*([^)]*)/i,
        xt = /^(none|table(?!-c[ea]).+)/,
        bt = new RegExp('^(' + Fe + ')(.*)$', 'i'),
        wt = {
            position: 'absolute',
            visibility: 'hidden',
            display: 'block'
        },
        Tt = {
            letterSpacing: '0',
            fontWeight: '400'
        },
        Ct = [
            'Webkit',
            'O',
            'Moz',
            'ms'
        ],
        Et = re.createElement('div').style;
    pe.extend({
        cssHooks: {
            opacity: {
                get: function (e, t) {
                    if (t) {
                        var n = gt(e, 'opacity');
                        return '' === n ? '1' : n
                    }
                }
            }
        },
        cssNumber: {
            animationIterationCount: !0,
            columnCount: !0,
            fillOpacity: !0,
            flexGrow: !0,
            flexShrink: !0,
            fontWeight: !0,
            lineHeight: !0,
            opacity: !0,
            order: !0,
            orphans: !0,
            widows: !0,
            zIndex: !0,
            zoom: !0
        },
        cssProps: {
            'float': fe.cssFloat ? 'cssFloat' : 'styleFloat'
        },
        style: function (e, t, n, r) {
            if (e && 3 !== e.nodeType && 8 !== e.nodeType && e.style) {
                var i,
                    o,
                    a,
                    s = pe.camelCase(t),
                    u = e.style;
                if (t = pe.cssProps[s] || (pe.cssProps[s] = H(s) || s), a = pe.cssHooks[t] || pe.cssHooks[s], void 0 === n) return a && 'get' in a && void 0 !== (i = a.get(e, !1, r)) ? i : u[t];
                if (o = typeof n, 'string' === o && (i = Me.exec(n)) && i[1] && (n = d(e, t, i), o = 'number'), null != n && n === n && ('number' === o && (n += i && i[3] || (pe.cssNumber[s] ? '' : 'px')), fe.clearCloneStyle || '' !== n || 0 !== t.indexOf('background') || (u[t] = 'inherit'), !(a && 'set' in a && void 0 === (n = a.set(e, n, r))))) try {
                    u[t] = n
                } catch (l) {
                }
            }
        },
        css: function (e, t, n, r) {
            var i,
                o,
                a,
                s = pe.camelCase(t);
            return t = pe.cssProps[s] || (pe.cssProps[s] = H(s) || s),
                a = pe.cssHooks[t] || pe.cssHooks[s],
            a && 'get' in a && (o = a.get(e, !0, n)),
            void 0 === o && (o = gt(e, t, r)),
            'normal' === o && t in Tt && (o = Tt[t]),
                '' === n || n ? (i = parseFloat(o), n === !0 || isFinite(i) ? i || 0 : o) : o
        }
    }),
        pe.each(['height',
            'width'], function (e, t) {
            pe.cssHooks[t] = {
                get: function (e, n, r) {
                    if (n) return xt.test(pe.css(e, 'display')) && 0 === e.offsetWidth ? dt(e, wt, function () {
                        return M(e, t, r)
                    }) : M(e, t, r)
                },
                set: function (e, n, r) {
                    var i = r && ht(e);
                    return _(e, n, r ? F(e, t, r, fe.boxSizing && 'border-box' === pe.css(e, 'boxSizing', !1, i), i) : 0)
                }
            }
        }),
    fe.opacity || (pe.cssHooks.opacity = {
        get: function (e, t) {
            return vt.test((t && e.currentStyle ? e.currentStyle.filter : e.style.filter) || '') ? 0.01 * parseFloat(RegExp.$1) + '' : t ? '1' : ''
        },
        set: function (e, t) {
            var n = e.style,
                r = e.currentStyle,
                i = pe.isNumeric(t) ? 'alpha(opacity=' + 100 * t + ')' : '',
                o = r && r.filter || n.filter || '';
            n.zoom = 1,
            (t >= 1 || '' === t) && '' === pe.trim(o.replace(yt, '')) && n.removeAttribute && (n.removeAttribute('filter'), '' === t || r && !r.filter) || (n.filter = yt.test(o) ? o.replace(yt, i) : o + ' ' + i)
        }
    }),
        pe.cssHooks.marginRight = L(fe.reliableMarginRight, function (e, t) {
            if (t) return dt(e, {
                display: 'inline-block'
            }, gt, [
                e,
                'marginRight'
            ])
        }),
        pe.cssHooks.marginLeft = L(fe.reliableMarginLeft, function (e, t) {
            if (t) return (parseFloat(gt(e, 'marginLeft')) || (pe.contains(e.ownerDocument, e) ? e.getBoundingClientRect().left - dt(e, {
                marginLeft: 0
            }, function () {
                return e.getBoundingClientRect().left
            }) : 0)) + 'px'
        }),
        pe.each({
            margin: '',
            padding: '',
            border: 'Width'
        }, function (e, t) {
            pe.cssHooks[e + t] = {
                expand: function (n) {
                    for (var r = 0, i = {}, o = 'string' == typeof n ? n.split(' ') : [
                        n
                    ]; r < 4; r++) i[e + Oe[r] + t] = o[r] || o[r - 2] || o[0];
                    return i
                }
            },
            ct.test(e) || (pe.cssHooks[e + t].set = _)
        }),
        pe.fn.extend({
            css: function (e, t) {
                return Pe(this, function (e, t, n) {
                    var r,
                        i,
                        o = {},
                        a = 0;
                    if (pe.isArray(t)) {
                        for (r = ht(e), i = t.length; a < i; a++) o[t[a]] = pe.css(e, t[a], !1, r);
                        return o
                    }
                    return void 0 !== n ? pe.style(e, t, n) : pe.css(e, t)
                }, e, t, arguments.length > 1)
            },
            show: function () {
                return q(this, !0)
            },
            hide: function () {
                return q(this)
            },
            toggle: function (e) {
                return 'boolean' == typeof e ? e ? this.show() : this.hide() : this.each(function () {
                    Re(this) ? pe(this).show() : pe(this).hide()
                })
            }
        }),
        pe.Tween = O,
        O.prototype = {
            constructor: O,
            init: function (e, t, n, r, i, o) {
                this.elem = e,
                    this.prop = n,
                    this.easing = i || pe.easing._default,
                    this.options = t,
                    this.start = this.now = this.cur(),
                    this.end = r,
                    this.unit = o || (pe.cssNumber[n] ? '' : 'px')
            },
            cur: function () {
                var e = O.propHooks[this.prop];
                return e && e.get ? e.get(this) : O.propHooks._default.get(this)
            },
            run: function (e) {
                var t,
                    n = O.propHooks[this.prop];
                return this.options.duration ? this.pos = t = pe.easing[this.easing](e, this.options.duration * e, 0, 1, this.options.duration) : this.pos = t = e,
                    this.now = (this.end - this.start) * t + this.start,
                this.options.step && this.options.step.call(this.elem, this.now, this),
                    n && n.set ? n.set(this) : O.propHooks._default.set(this),
                    this
            }
        },
        O.prototype.init.prototype = O.prototype,
        O.propHooks = {
            _default: {
                get: function (e) {
                    var t;
                    return 1 !== e.elem.nodeType || null != e.elem[e.prop] && null == e.elem.style[e.prop] ? e.elem[e.prop] : (t = pe.css(e.elem, e.prop, ''), t && 'auto' !== t ? t : 0)
                },
                set: function (e) {
                    pe.fx.step[e.prop] ? pe.fx.step[e.prop](e) : 1 !== e.elem.nodeType || null == e.elem.style[pe.cssProps[e.prop]] && !pe.cssHooks[e.prop] ? e.elem[e.prop] = e.now : pe.style(e.elem, e.prop, e.now + e.unit)
                }
            }
        },
        O.propHooks.scrollTop = O.propHooks.scrollLeft = {
            set: function (e) {
                e.elem.nodeType && e.elem.parentNode && (e.elem[e.prop] = e.now)
            }
        },
        pe.easing = {
            linear: function (e) {
                return e
            },
            swing: function (e) {
                return 0.5 - Math.cos(e * Math.PI) / 2
            },
            _default: 'swing'
        },
        pe.fx = O.prototype.init,
        pe.fx.step = {};
    var Nt,
        kt,
        St = /^(?:toggle|show|hide)$/,
        At = /queueHooks$/;
    pe.Animation = pe.extend($, {
        tweeners: {
            '*': [
                function (e, t) {
                    var n = this.createTween(e, t);
                    return d(n.elem, e, Me.exec(t), n),
                        n
                }
            ]
        },
        tweener: function (e, t) {
            pe.isFunction(e) ? (t = e, e = [
                '*'
            ]) : e = e.match(De);
            for (var n, r = 0, i = e.length; r < i; r++) n = e[r],
                $.tweeners[n] = $.tweeners[n] || [],
                $.tweeners[n].unshift(t)
        },
        prefilters: [
            W
        ],
        prefilter: function (e, t) {
            t ? $.prefilters.unshift(e) : $.prefilters.push(e)
        }
    }),
        pe.speed = function (e, t, n) {
            var r = e && 'object' == typeof e ? pe.extend({}, e) : {
                complete: n || !n && t || pe.isFunction(e) && e,
                duration: e,
                easing: n && t || t && !pe.isFunction(t) && t
            };
            return r.duration = pe.fx.off ? 0 : 'number' == typeof r.duration ? r.duration : r.duration in pe.fx.speeds ? pe.fx.speeds[r.duration] : pe.fx.speeds._default,
            null != r.queue && r.queue !== !0 || (r.queue = 'fx'),
                r.old = r.complete,
                r.complete = function () {
                    pe.isFunction(r.old) && r.old.call(this),
                    r.queue && pe.dequeue(this, r.queue)
                },
                r
        },
        pe.fn.extend({
            fadeTo: function (e, t, n, r) {
                return this.filter(Re).css('opacity', 0).show().end().animate({
                    opacity: t
                }, e, n, r)
            },
            animate: function (e, t, n, r) {
                var i = pe.isEmptyObject(e),
                    o = pe.speed(t, n, r),
                    a = function () {
                        var t = $(this, pe.extend({}, e), o);
                        (i || pe._data(this, 'finish')) && t.stop(!0)
                    };
                return a.finish = a,
                    i || o.queue === !1 ? this.each(a) : this.queue(o.queue, a)
            },
            stop: function (e, t, n) {
                var r = function (e) {
                    var t = e.stop;
                    delete e.stop,
                        t(n)
                };
                return 'string' != typeof e && (n = t, t = e, e = void 0),
                t && e !== !1 && this.queue(e || 'fx', []),
                    this.each(function () {
                        var t = !0,
                            i = null != e && e + 'queueHooks',
                            o = pe.timers,
                            a = pe._data(this);
                        if (i) a[i] && a[i].stop && r(a[i]);
                        else for (i in a) a[i] && a[i].stop && At.test(i) && r(a[i]);
                        for (i = o.length; i--;) o[i].elem !== this || null != e && o[i].queue !== e || (o[i].anim.stop(n), t = !1, o.splice(i, 1));
                        !t && n || pe.dequeue(this, e)
                    })
            },
            finish: function (e) {
                return e !== !1 && (e = e || 'fx'),
                    this.each(function () {
                        var t,
                            n = pe._data(this),
                            r = n[e + 'queue'],
                            i = n[e + 'queueHooks'],
                            o = pe.timers,
                            a = r ? r.length : 0;
                        for (n.finish = !0, pe.queue(this, e, []), i && i.stop && i.stop.call(this, !0), t = o.length; t--;) o[t].elem === this && o[t].queue === e && (o[t].anim.stop(!0), o.splice(t, 1));
                        for (t = 0; t < a; t++) r[t] && r[t].finish && r[t].finish.call(this);
                        delete n.finish
                    })
            }
        }),
        pe.each(['toggle',
            'show',
            'hide'], function (e, t) {
            var n = pe.fn[t];
            pe.fn[t] = function (e, r, i) {
                return null == e || 'boolean' == typeof e ? n.apply(this, arguments) : this.animate(P(t, !0), e, r, i)
            }
        }),
        pe.each({
            slideDown: P('show'),
            slideUp: P('hide'),
            slideToggle: P('toggle'),
            fadeIn: {
                opacity: 'show'
            },
            fadeOut: {
                opacity: 'hide'
            },
            fadeToggle: {
                opacity: 'toggle'
            }
        }, function (e, t) {
            pe.fn[e] = function (e, n, r) {
                return this.animate(t, e, n, r)
            }
        }),
        pe.timers = [],
        pe.fx.tick = function () {
            var e,
                t = pe.timers,
                n = 0;
            for (Nt = pe.now(); n < t.length; n++) e = t[n],
            e() || t[n] !== e || t.splice(n--, 1);
            t.length || pe.fx.stop(),
                Nt = void 0
        },
        pe.fx.timer = function (e) {
            pe.timers.push(e),
                e() ? pe.fx.start() : pe.timers.pop()
        },
        pe.fx.interval = 13,
        pe.fx.start = function () {
            kt || (kt = e.setInterval(pe.fx.tick, pe.fx.interval))
        },
        pe.fx.stop = function () {
            e.clearInterval(kt),
                kt = null
        },
        pe.fx.speeds = {
            slow: 600,
            fast: 200,
            _default: 400
        },
        pe.fn.delay = function (t, n) {
            return t = pe.fx ? pe.fx.speeds[t] || t : t,
                n = n || 'fx',
                this.queue(n, function (n, r) {
                    var i = e.setTimeout(n, t);
                    r.stop = function () {
                        e.clearTimeout(i)
                    }
                })
        },
        function () {
            var e,
                t = re.createElement('input'),
                n = re.createElement('div'),
                r = re.createElement('select'),
                i = r.appendChild(re.createElement('option'));
            n = re.createElement('div'),
                n.setAttribute('className', 't'),
                n.innerHTML = '  <link/><table></table><a href=\'/a\'>a</a><input type=\'checkbox\'/>',
                e = n.getElementsByTagName('a') [0],
                t.setAttribute('type', 'checkbox'),
                n.appendChild(t),
                e = n.getElementsByTagName('a') [0],
                e.style.cssText = 'top:1px',
                fe.getSetAttribute = 't' !== n.className,
                fe.style = /top/.test(e.getAttribute('style')),
                fe.hrefNormalized = '/a' === e.getAttribute('href'),
                fe.checkOn = !!t.value,
                fe.optSelected = i.selected,
                fe.enctype = !!re.createElement('form').enctype,
                r.disabled = !0,
                fe.optDisabled = !i.disabled,
                t = re.createElement('input'),
                t.setAttribute('value', ''),
                fe.input = '' === t.getAttribute('value'),
                t.value = 't',
                t.setAttribute('type', 'radio'),
                fe.radioValue = 't' === t.value
        }();
    var Dt = /\r/g,
        jt = /[\x20\t\r\n\f]+/g;
    pe.fn.extend({
        val: function (e) {
            var t,
                n,
                r,
                i = this[0];
            {
                if (arguments.length) return r = pe.isFunction(e),
                    this.each(function (n) {
                        var i;
                        1 === this.nodeType && (i = r ? e.call(this, n, pe(this).val()) : e, null == i ? i = '' : 'number' == typeof i ? i += '' : pe.isArray(i) && (i = pe.map(i, function (e) {
                            return null == e ? '' : e + ''
                        })), t = pe.valHooks[this.type] || pe.valHooks[this.nodeName.toLowerCase()], t && 'set' in t && void 0 !== t.set(this, i, 'value') || (this.value = i))
                    });
                if (i) return t = pe.valHooks[i.type] || pe.valHooks[i.nodeName.toLowerCase()],
                    t && 'get' in t && void 0 !== (n = t.get(i, 'value')) ? n : (n = i.value, 'string' == typeof n ? n.replace(Dt, '') : null == n ? '' : n)
            }
        }
    }),
        pe.extend({
            valHooks: {
                option: {
                    get: function (e) {
                        var t = pe.find.attr(e, 'value');
                        return null != t ? t : pe.trim(pe.text(e)).replace(jt, ' ')
                    }
                },
                select: {
                    get: function (e) {
                        for (var t, n, r = e.options, i = e.selectedIndex, o = 'select-one' === e.type || i < 0, a = o ? null : [], s = o ? i + 1 : r.length, u = i < 0 ? s : o ? i : 0; u < s; u++) if (n = r[u], (n.selected || u === i) && (fe.optDisabled ? !n.disabled : null === n.getAttribute('disabled')) && (!n.parentNode.disabled || !pe.nodeName(n.parentNode, 'optgroup'))) {
                            if (t = pe(n).val(), o) return t;
                            a.push(t)
                        }
                        return a
                    },
                    set: function (e, t) {
                        for (var n, r, i = e.options, o = pe.makeArray(t), a = i.length; a--;) if (r = i[a], pe.inArray(pe.valHooks.option.get(r), o) > -1) try {
                            r.selected = n = !0
                        } catch (s) {
                            r.scrollHeight
                        } else r.selected = !1;
                        return n || (e.selectedIndex = -1),
                            i
                    }
                }
            }
        }),
        pe.each(['radio',
            'checkbox'], function () {
            pe.valHooks[this] = {
                set: function (e, t) {
                    if (pe.isArray(t)) return e.checked = pe.inArray(pe(e).val(), t) > -1
                }
            },
            fe.checkOn || (pe.valHooks[this].get = function (e) {
                return null === e.getAttribute('value') ? 'on' : e.value
            })
        });
    var Lt,
        Ht,
        qt = pe.expr.attrHandle,
        _t = /^(?:checked|selected)$/i,
        Ft = fe.getSetAttribute,
        Mt = fe.input;
    pe.fn.extend({
        attr: function (e, t) {
            return Pe(this, pe.attr, e, t, arguments.length > 1)
        },
        removeAttr: function (e) {
            return this.each(function () {
                pe.removeAttr(this, e)
            })
        }
    }),
        pe.extend({
            attr: function (e, t, n) {
                var r,
                    i,
                    o = e.nodeType;
                if (3 !== o && 8 !== o && 2 !== o) return 'undefined' == typeof e.getAttribute ? pe.prop(e, t, n) : (1 === o && pe.isXMLDoc(e) || (t = t.toLowerCase(), i = pe.attrHooks[t] || (pe.expr.match.bool.test(t) ? Ht : Lt)), void 0 !== n ? null === n ? void pe.removeAttr(e, t) : i && 'set' in i && void 0 !== (r = i.set(e, n, t)) ? r : (e.setAttribute(t, n + ''), n) : i && 'get' in i && null !== (r = i.get(e, t)) ? r : (r = pe.find.attr(e, t), null == r ? void 0 : r))
            },
            attrHooks: {
                type: {
                    set: function (e, t) {
                        if (!fe.radioValue && 'radio' === t && pe.nodeName(e, 'input')) {
                            var n = e.value;
                            return e.setAttribute('type', t),
                            n && (e.value = n),
                                t
                        }
                    }
                }
            },
            removeAttr: function (e, t) {
                var n,
                    r,
                    i = 0,
                    o = t && t.match(De);
                if (o && 1 === e.nodeType) for (; n = o[i++];) r = pe.propFix[n] || n,
                    pe.expr.match.bool.test(n) ? Mt && Ft || !_t.test(n) ? e[r] = !1 : e[pe.camelCase('default-' + n)] = e[r] = !1 : pe.attr(e, n, ''),
                    e.removeAttribute(Ft ? n : r)
            }
        }),
        Ht = {
            set: function (e, t, n) {
                return t === !1 ? pe.removeAttr(e, n) : Mt && Ft || !_t.test(n) ? e.setAttribute(!Ft && pe.propFix[n] || n, n) : e[pe.camelCase('default-' + n)] = e[n] = !0,
                    n
            }
        },
        pe.each(pe.expr.match.bool.source.match(/\w+/g), function (e, t) {
            var n = qt[t] || pe.find.attr;
            Mt && Ft || !_t.test(t) ? qt[t] = function (e, t, r) {
                    var i,
                        o;
                    return r || (o = qt[t], qt[t] = i, i = null != n(e, t, r) ? t.toLowerCase() : null, qt[t] = o),
                        i
                }
                : qt[t] = function (e, t, n) {
                    if (!n) return e[pe.camelCase('default-' + t)] ? t.toLowerCase() : null
                }
        }),
    Mt && Ft || (pe.attrHooks.value = {
        set: function (e, t, n) {
            return pe.nodeName(e, 'input') ? void (e.defaultValue = t) : Lt && Lt.set(e, t, n)
        }
    }),
    Ft || (Lt = {
        set: function (e, t, n) {
            var r = e.getAttributeNode(n);
            if (r || e.setAttributeNode(r = e.ownerDocument.createAttribute(n)), r.value = t += '', 'value' === n || t === e.getAttribute(n)) return t
        }
    }, qt.id = qt.name = qt.coords = function (e, t, n) {
        var r;
        if (!n) return (r = e.getAttributeNode(t)) && '' !== r.value ? r.value : null
    }, pe.valHooks.button = {
        get: function (e, t) {
            var n = e.getAttributeNode(t);
            if (n && n.specified) return n.value
        },
        set: Lt.set
    }, pe.attrHooks.contenteditable = {
        set: function (e, t, n) {
            Lt.set(e, '' !== t && t, n)
        }
    }, pe.each(['width',
        'height'], function (e, t) {
        pe.attrHooks[t] = {
            set: function (e, n) {
                if ('' === n) return e.setAttribute(t, 'auto'),
                    n
            }
        }
    })),
    fe.style || (pe.attrHooks.style = {
        get: function (e) {
            return e.style.cssText || void 0
        },
        set: function (e, t) {
            return e.style.cssText = t + ''
        }
    });
    var Ot = /^(?:input|select|textarea|button|object)$/i,
        Rt = /^(?:a|area)$/i;
    pe.fn.extend({
        prop: function (e, t) {
            return Pe(this, pe.prop, e, t, arguments.length > 1)
        },
        removeProp: function (e) {
            return e = pe.propFix[e] || e,
                this.each(function () {
                    try {
                        this[e] = void 0,
                            delete this[e]
                    } catch (t) {
                    }
                })
        }
    }),
        pe.extend({
            prop: function (e, t, n) {
                var r,
                    i,
                    o = e.nodeType;
                if (3 !== o && 8 !== o && 2 !== o) return 1 === o && pe.isXMLDoc(e) || (t = pe.propFix[t] || t, i = pe.propHooks[t]),
                    void 0 !== n ? i && 'set' in i && void 0 !== (r = i.set(e, n, t)) ? r : e[t] = n : i && 'get' in i && null !== (r = i.get(e, t)) ? r : e[t]
            },
            propHooks: {
                tabIndex: {
                    get: function (e) {
                        var t = pe.find.attr(e, 'tabindex');
                        return t ? parseInt(t, 10) : Ot.test(e.nodeName) || Rt.test(e.nodeName) && e.href ? 0 : -1
                    }
                }
            },
            propFix: {
                'for': 'htmlFor',
                'class': 'className'
            }
        }),
    fe.hrefNormalized || pe.each(['href',
        'src'], function (e, t) {
        pe.propHooks[t] = {
            get: function (e) {
                return e.getAttribute(t, 4)
            }
        }
    }),
    fe.optSelected || (pe.propHooks.selected = {
        get: function (e) {
            var t = e.parentNode;
            return t && (t.selectedIndex, t.parentNode && t.parentNode.selectedIndex),
                null
        },
        set: function (e) {
            var t = e.parentNode;
            t && (t.selectedIndex, t.parentNode && t.parentNode.selectedIndex)
        }
    }),
        pe.each(['tabIndex',
            'readOnly',
            'maxLength',
            'cellSpacing',
            'cellPadding',
            'rowSpan',
            'colSpan',
            'useMap',
            'frameBorder',
            'contentEditable'], function () {
            pe.propFix[this.toLowerCase()] = this
        }),
    fe.enctype || (pe.propFix.enctype = 'encoding');
    var Pt = /[\t\r\n\f]/g;
    pe.fn.extend({
        addClass: function (e) {
            var t,
                n,
                r,
                i,
                o,
                a,
                s,
                u = 0;
            if (pe.isFunction(e)) return this.each(function (t) {
                pe(this).addClass(e.call(this, t, z(this)))
            });
            if ('string' == typeof e && e) for (t = e.match(De) || []; n = this[u++];) if (i = z(n), r = 1 === n.nodeType && (' ' + i + ' ').replace(Pt, ' ')) {
                for (a = 0; o = t[a++];) r.indexOf(' ' + o + ' ') < 0 && (r += o + ' ');
                s = pe.trim(r),
                i !== s && pe.attr(n, 'class', s)
            }
            return this
        },
        removeClass: function (e) {
            var t,
                n,
                r,
                i,
                o,
                a,
                s,
                u = 0;
            if (pe.isFunction(e)) return this.each(function (t) {
                pe(this).removeClass(e.call(this, t, z(this)))
            });
            if (!arguments.length) return this.attr('class', '');
            if ('string' == typeof e && e) for (t = e.match(De) || []; n = this[u++];) if (i = z(n), r = 1 === n.nodeType && (' ' + i + ' ').replace(Pt, ' ')) {
                for (a = 0; o = t[a++];) for (; r.indexOf(' ' + o + ' ') > -1;) r = r.replace(' ' + o + ' ', ' ');
                s = pe.trim(r),
                i !== s && pe.attr(n, 'class', s)
            }
            return this
        },
        toggleClass: function (e, t) {
            var n = typeof e;
            return 'boolean' == typeof t && 'string' === n ? t ? this.addClass(e) : this.removeClass(e) : pe.isFunction(e) ? this.each(function (n) {
                pe(this).toggleClass(e.call(this, n, z(this), t), t)
            }) : this.each(function () {
                var t,
                    r,
                    i,
                    o;
                if ('string' === n) for (r = 0, i = pe(this), o = e.match(De) || []; t = o[r++];) i.hasClass(t) ? i.removeClass(t) : i.addClass(t);
                else void 0 !== e && 'boolean' !== n || (t = z(this), t && pe._data(this, '__className__', t), pe.attr(this, 'class', t || e === !1 ? '' : pe._data(this, '__className__') || ''))
            })
        },
        hasClass: function (e) {
            var t,
                n,
                r = 0;
            for (t = ' ' + e + ' '; n = this[r++];) if (1 === n.nodeType && (' ' + z(n) + ' ').replace(Pt, ' ').indexOf(t) > -1) return !0;
            return !1
        }
    }),
        pe.each('blur focus focusin focusout load resize scroll unload click dblclick mousedown mouseup mousemove mouseover mouseout mouseenter mouseleave change select submit keydown keypress keyup error contextmenu'.split(' '), function (e, t) {
            pe.fn[t] = function (e, n) {
                return arguments.length > 0 ? this.on(t, null, e, n) : this.trigger(t)
            }
        }),
        pe.fn.extend({
            hover: function (e, t) {
                return this.mouseenter(e).mouseleave(t || e)
            }
        });
    var Bt = e.location,
        Wt = pe.now(),
        It = /\?/,
        $t = /(,)|(\[|{)|(}|])|"(?:[^"\\\r\n]|\\["\\\/bfnrt]|\\u[\da-fA-F]{4})*"\s*:?|true|false|null|-?(?!0\d)\d+(?:\.\d+|)(?:[eE][+-]?\d+|)/g;
    pe.parseJSON = function (t) {
        if (e.JSON && e.JSON.parse) return e.JSON.parse(t + '');
        var n,
            r = null,
            i = pe.trim(t + '');
        return i && !pe.trim(i.replace($t, function (e, t, i, o) {
            return n && t && (r = 0),
                0 === r ? e : (n = i || t, r += !o - !i, '')
        })) ? Function('return ' + i)() : pe.error('Invalid JSON: ' + t)
    },
        pe.parseXML = function (t) {
            var n,
                r;
            if (!t || 'string' != typeof t) return null;
            try {
                e.DOMParser ? (r = new e.DOMParser, n = r.parseFromString(t, 'text/xml')) : (n = new e.ActiveXObject('Microsoft.XMLDOM'), n.async = 'false', n.loadXML(t))
            } catch (i) {
                n = void 0
            }
            return n && n.documentElement && !n.getElementsByTagName('parsererror').length || pe.error('Invalid XML: ' + t),
                n
        };
    var zt = /#.*$/,
        Xt = /([?&])_=[^&]*/,
        Ut = /^(.*?):[ \t]*([^\r\n]*)\r?$/gm,
        Vt = /^(?:about|app|app-storage|.+-extension|file|res|widget):$/,
        Yt = /^(?:GET|HEAD)$/,
        Jt = /^\/\//,
        Gt = /^([\w.+-]+:)(?:\/\/(?:[^\/?#]*@|)([^\/?#:]*)(?::(\d+)|)|)/,
        Kt = {},
        Qt = {},
        Zt = '*/'.concat('*'),
        en = Bt.href,
        tn = Gt.exec(en.toLowerCase()) || [];
    pe.extend({
        active: 0,
        lastModified: {},
        etag: {},
        ajaxSettings: {
            url: en,
            type: 'GET',
            isLocal: Vt.test(tn[1]),
            global: !0,
            processData: !0,
            async: !0,
            contentType: 'application/x-www-form-urlencoded; charset=UTF-8',
            accepts: {
                '*': Zt,
                text: 'text/plain',
                html: 'text/html',
                xml: 'application/xml, text/xml',
                json: 'application/json, text/javascript'
            },
            contents: {
                xml: /\bxml\b/,
                html: /\bhtml/,
                json: /\bjson\b/
            },
            responseFields: {
                xml: 'responseXML',
                text: 'responseText',
                json: 'responseJSON'
            },
            converters: {
                '* text': String,
                'text html': !0,
                'text json': pe.parseJSON,
                'text xml': pe.parseXML
            },
            flatOptions: {
                url: !0,
                context: !0
            }
        },
        ajaxSetup: function (e, t) {
            return t ? V(V(e, pe.ajaxSettings), t) : V(pe.ajaxSettings, e)
        },
        ajaxPrefilter: X(Kt),
        ajaxTransport: X(Qt),
        ajax: function (t, n) {
            function r(t, n, r, i) {
                var o,
                    f,
                    v,
                    x,
                    w,
                    C = n;
                2 !== b && (b = 2, u && e.clearTimeout(u), c = void 0, s = i || '', T.readyState = t > 0 ? 4 : 0, o = t >= 200 && t < 300 || 304 === t, r && (x = Y(d, T, r)), x = J(d, x, T, o), o ? (d.ifModified && (w = T.getResponseHeader('Last-Modified'), w && (pe.lastModified[a] = w), w = T.getResponseHeader('etag'), w && (pe.etag[a] = w)), 204 === t || 'HEAD' === d.type ? C = 'nocontent' : 304 === t ? C = 'notmodified' : (C = x.state, f = x.data, v = x.error, o = !v)) : (v = C, !t && C || (C = 'error', t < 0 && (t = 0))), T.status = t, T.statusText = (n || C) + '', o ? g.resolveWith(p, [
                    f,
                    C,
                    T
                ]) : g.rejectWith(p, [
                    T,
                    C,
                    v
                ]), T.statusCode(y), y = void 0, l && h.trigger(o ? 'ajaxSuccess' : 'ajaxError', [
                    T,
                    d,
                    o ? f : v
                ]), m.fireWith(p, [
                    T,
                    C
                ]), l && (h.trigger('ajaxComplete', [
                    T,
                    d
                ]), --pe.active || pe.event.trigger('ajaxStop')))
            }

            'object' == typeof t && (n = t, t = void 0),
                n = n || {};
            var i,
                o,
                a,
                s,
                u,
                l,
                c,
                f,
                d = pe.ajaxSetup({}, n),
                p = d.context || d,
                h = d.context && (p.nodeType || p.jquery) ? pe(p) : pe.event,
                g = pe.Deferred(),
                m = pe.Callbacks('once memory'),
                y = d.statusCode || {},
                v = {},
                x = {},
                b = 0,
                w = 'canceled',
                T = {
                    readyState: 0,
                    getResponseHeader: function (e) {
                        var t;
                        if (2 === b) {
                            if (!f) for (f = {}; t = Ut.exec(s);) f[t[1].toLowerCase()] = t[2];
                            t = f[e.toLowerCase()]
                        }
                        return null == t ? null : t
                    },
                    getAllResponseHeaders: function () {
                        return 2 === b ? s : null
                    },
                    setRequestHeader: function (e, t) {
                        var n = e.toLowerCase();
                        return b || (e = x[n] = x[n] || e, v[e] = t),
                            this
                    },
                    overrideMimeType: function (e) {
                        return b || (d.mimeType = e),
                            this
                    },
                    statusCode: function (e) {
                        var t;
                        if (e) if (b < 2) for (t in e) y[t] = [
                            y[t],
                            e[t]
                        ];
                        else T.always(e[T.status]);
                        return this
                    },
                    abort: function (e) {
                        var t = e || w;
                        return c && c.abort(t),
                            r(0, t),
                            this
                    }
                };
            if (g.promise(T).complete = m.add, T.success = T.done, T.error = T.fail, d.url = ((t || d.url || en) + '').replace(zt, '').replace(Jt, tn[1] + '//'), d.type = n.method || n.type || d.method || d.type, d.dataTypes = pe.trim(d.dataType || '*').toLowerCase().match(De) || [
                ''
            ], null == d.crossDomain && (i = Gt.exec(d.url.toLowerCase()), d.crossDomain = !(!i || i[1] === tn[1] && i[2] === tn[2] && (i[3] || ('http:' === i[1] ? '80' : '443')) === (tn[3] || ('http:' === tn[1] ? '80' : '443')))), d.data && d.processData && 'string' != typeof d.data && (d.data = pe.param(d.data, d.traditional)), U(Kt, d, n, T), 2 === b) return T;
            l = pe.event && d.global,
            l && 0 === pe.active++ && pe.event.trigger('ajaxStart'),
                d.type = d.type.toUpperCase(),
                d.hasContent = !Yt.test(d.type),
                a = d.url,
            d.hasContent || (d.data && (a = d.url += (It.test(a) ? '&' : '?') + d.data, delete d.data), d.cache === !1 && (d.url = Xt.test(a) ? a.replace(Xt, '$1_=' + Wt++) : a + (It.test(a) ? '&' : '?') + '_=' + Wt++)),
            d.ifModified && (pe.lastModified[a] && T.setRequestHeader('If-Modified-Since', pe.lastModified[a]), pe.etag[a] && T.setRequestHeader('If-None-Match', pe.etag[a])),
            (d.data && d.hasContent && d.contentType !== !1 || n.contentType) && T.setRequestHeader('Content-Type', d.contentType),
                T.setRequestHeader('Accept', d.dataTypes[0] && d.accepts[d.dataTypes[0]] ? d.accepts[d.dataTypes[0]] + ('*' !== d.dataTypes[0] ? ', ' + Zt + '; q=0.01' : '') : d.accepts['*']);
            for (o in d.headers) T.setRequestHeader(o, d.headers[o]);
            if (d.beforeSend && (d.beforeSend.call(p, T, d) === !1 || 2 === b)) return T.abort();
            w = 'abort';
            for (o in {
                success: 1,
                error: 1,
                complete: 1
            }) T[o](d[o]);
            if (c = U(Qt, d, n, T)) {
                if (T.readyState = 1, l && h.trigger('ajaxSend', [
                    T,
                    d
                ]), 2 === b) return T;
                d.async && d.timeout > 0 && (u = e.setTimeout(function () {
                    T.abort('timeout')
                }, d.timeout));
                try {
                    b = 1,
                        c.send(v, r)
                } catch (C) {
                    if (!(b < 2)) throw C;
                    r(-1, C)
                }
            } else r(-1, 'No Transport');
            return T
        },
        getJSON: function (e, t, n) {
            return pe.get(e, t, n, 'json')
        },
        getScript: function (e, t) {
            return pe.get(e, void 0, t, 'script')
        }
    }),
        pe.each(['get',
            'post'], function (e, t) {
            pe[t] = function (e, n, r, i) {
                return pe.isFunction(n) && (i = i || r, r = n, n = void 0),
                    pe.ajax(pe.extend({
                        url: e,
                        type: t,
                        dataType: i,
                        data: n,
                        success: r
                    }, pe.isPlainObject(e) && e))
            }
        }),
        pe._evalUrl = function (e) {
            return pe.ajax({
                url: e,
                type: 'GET',
                dataType: 'script',
                cache: !0,
                async: !1,
                global: !1,
                'throws': !0
            })
        },
        pe.fn.extend({
            wrapAll: function (e) {
                if (pe.isFunction(e)) return this.each(function (t) {
                    pe(this).wrapAll(e.call(this, t))
                });
                if (this[0]) {
                    var t = pe(e, this[0].ownerDocument).eq(0).clone(!0);
                    this[0].parentNode && t.insertBefore(this[0]),
                        t.map(function () {
                            for (var e = this; e.firstChild && 1 === e.firstChild.nodeType;) e = e.firstChild;
                            return e
                        }).append(this)
                }
                return this
            },
            wrapInner: function (e) {
                return pe.isFunction(e) ? this.each(function (t) {
                    pe(this).wrapInner(e.call(this, t))
                }) : this.each(function () {
                    var t = pe(this),
                        n = t.contents();
                    n.length ? n.wrapAll(e) : t.append(e)
                })
            },
            wrap: function (e) {
                var t = pe.isFunction(e);
                return this.each(function (n) {
                    pe(this).wrapAll(t ? e.call(this, n) : e)
                })
            },
            unwrap: function () {
                return this.parent().each(function () {
                    pe.nodeName(this, 'body') || pe(this).replaceWith(this.childNodes)
                }).end()
            }
        }),
        pe.expr.filters.hidden = function (e) {
            return fe.reliableHiddenOffsets() ? e.offsetWidth <= 0 && e.offsetHeight <= 0 && !e.getClientRects().length : K(e)
        },
        pe.expr.filters.visible = function (e) {
            return !pe.expr.filters.hidden(e)
        };
    var nn = /%20/g,
        rn = /\[\]$/,
        on = /\r?\n/g,
        an = /^(?:submit|button|image|reset|file)$/i,
        sn = /^(?:input|select|textarea|keygen)/i;
    pe.param = function (e, t) {
        var n,
            r = [],
            i = function (e, t) {
                t = pe.isFunction(t) ? t() : null == t ? '' : t,
                    r[r.length] = encodeURIComponent(e) + '=' + encodeURIComponent(t)
            };
        if (void 0 === t && (t = pe.ajaxSettings && pe.ajaxSettings.traditional), pe.isArray(e) || e.jquery && !pe.isPlainObject(e)) pe.each(e, function () {
            i(this.name, this.value)
        });
        else for (n in e) Q(n, e[n], t, i);
        return r.join('&').replace(nn, '+')
    },
        pe.fn.extend({
            serialize: function () {
                return pe.param(this.serializeArray())
            },
            serializeArray: function () {
                return this.map(function () {
                    var e = pe.prop(this, 'elements');
                    return e ? pe.makeArray(e) : this
                }).filter(function () {
                    var e = this.type;
                    return this.name && !pe(this).is(':disabled') && sn.test(this.nodeName) && !an.test(e) && (this.checked || !Be.test(e))
                }).map(function (e, t) {
                    var n = pe(this).val();
                    return null == n ? null : pe.isArray(n) ? pe.map(n, function (e) {
                        return {
                            name: t.name,
                            value: e.replace(on, '\r\n')
                        }
                    }) : {
                        name: t.name,
                        value: n.replace(on, '\r\n')
                    }
                }).get()
            }
        }),
        pe.ajaxSettings.xhr = void 0 !== e.ActiveXObject ? function () {
                return this.isLocal ? ee() : re.documentMode > 8 ? Z() : /^(get|post|head|put|delete|options)$/i.test(this.type) && Z() || ee()
            }
            : Z;
    var un = 0,
        ln = {},
        cn = pe.ajaxSettings.xhr();
    e.attachEvent && e.attachEvent('onunload', function () {
        for (var e in ln) ln[e](void 0, !0)
    }),
        fe.cors = !!cn && 'withCredentials' in cn,
        cn = fe.ajax = !!cn,
    cn && pe.ajaxTransport(function (t) {
        if (!t.crossDomain || fe.cors) {
            var n;
            return {
                send: function (r, i) {
                    var o,
                        a = t.xhr(),
                        s = ++un;
                    if (a.open(t.type, t.url, t.async, t.username, t.password), t.xhrFields) for (o in t.xhrFields) a[o] = t.xhrFields[o];
                    t.mimeType && a.overrideMimeType && a.overrideMimeType(t.mimeType),
                    t.crossDomain || r['X-Requested-With'] || (r['X-Requested-With'] = 'XMLHttpRequest');
                    for (o in r) void 0 !== r[o] && a.setRequestHeader(o, r[o] + '');
                    a.send(t.hasContent && t.data || null),
                        n = function (e, r) {
                            var o,
                                u,
                                l;
                            if (n && (r || 4 === a.readyState)) if (delete ln[s], n = void 0, a.onreadystatechange = pe.noop, r) 4 !== a.readyState && a.abort();
                            else {
                                l = {},
                                    o = a.status,
                                'string' == typeof a.responseText && (l.text = a.responseText);
                                try {
                                    u = a.statusText
                                } catch (c) {
                                    u = ''
                                }
                                o || !t.isLocal || t.crossDomain ? 1223 === o && (o = 204) : o = l.text ? 200 : 404
                            }
                            l && i(o, u, l, a.getAllResponseHeaders())
                        },
                        t.async ? 4 === a.readyState ? e.setTimeout(n) : a.onreadystatechange = ln[s] = n : n()
                },
                abort: function () {
                    n && n(void 0, !0)
                }
            }
        }
    }),
        pe.ajaxSetup({
            accepts: {
                script: 'text/javascript, application/javascript, application/ecmascript, application/x-ecmascript'
            },
            contents: {
                script: /\b(?:java|ecma)script\b/
            },
            converters: {
                'text script': function (e) {
                    return pe.globalEval(e),
                        e
                }
            }
        }),
        pe.ajaxPrefilter('script', function (e) {
            void 0 === e.cache && (e.cache = !1),
            e.crossDomain && (e.type = 'GET', e.global = !1)
        }),
        pe.ajaxTransport('script', function (e) {
            if (e.crossDomain) {
                var t,
                    n = re.head || pe('head') [0] || re.documentElement;
                return {
                    send: function (r, i) {
                        t = re.createElement('script'),
                            t.async = !0,
                        e.scriptCharset && (t.charset = e.scriptCharset),
                            t.src = e.url,
                            t.onload = t.onreadystatechange = function (e, n) {
                                (n || !t.readyState || /loaded|complete/.test(t.readyState)) && (t.onload = t.onreadystatechange = null, t.parentNode && t.parentNode.removeChild(t), t = null, n || i(200, 'success'))
                            },
                            n.insertBefore(t, n.firstChild)
                    },
                    abort: function () {
                        t && t.onload(void 0, !0)
                    }
                }
            }
        });
    var fn = [],
        dn = /(=)\?(?=&|$)|\?\?/;
    pe.ajaxSetup({
        jsonp: 'callback',
        jsonpCallback: function () {
            var e = fn.pop() || pe.expando + '_' + Wt++;
            return this[e] = !0,
                e
        }
    }),
        pe.ajaxPrefilter('json jsonp', function (t, n, r) {
            var i,
                o,
                a,
                s = t.jsonp !== !1 && (dn.test(t.url) ? 'url' : 'string' == typeof t.data && 0 === (t.contentType || '').indexOf('application/x-www-form-urlencoded') && dn.test(t.data) && 'data');
            if (s || 'jsonp' === t.dataTypes[0]) return i = t.jsonpCallback = pe.isFunction(t.jsonpCallback) ? t.jsonpCallback() : t.jsonpCallback,
                s ? t[s] = t[s].replace(dn, '$1' + i) : t.jsonp !== !1 && (t.url += (It.test(t.url) ? '&' : '?') + t.jsonp + '=' + i),
                t.converters['script json'] = function () {
                    return a || pe.error(i + ' was not called'),
                        a[0]
                },
                t.dataTypes[0] = 'json',
                o = e[i],
                e[i] = function () {
                    a = arguments
                },
                r.always(function () {
                    void 0 === o ? pe(e).removeProp(i) : e[i] = o,
                    t[i] && (t.jsonpCallback = n.jsonpCallback, fn.push(i)),
                    a && pe.isFunction(o) && o(a[0]),
                        a = o = void 0
                }),
                'script'
        }),
        pe.parseHTML = function (e, t, n) {
            if (!e || 'string' != typeof e) return null;
            'boolean' == typeof t && (n = t, t = !1),
                t = t || re;
            var r = Te.exec(e),
                i = !n && [];
            return r ? [
                t.createElement(r[1])
            ] : (r = y([e], t, i), i && i.length && pe(i).remove(), pe.merge([], r.childNodes))
        };
    var pn = pe.fn.load;
    return pe.fn.load = function (e, t, n) {
        if ('string' != typeof e && pn) return pn.apply(this, arguments);
        var r,
            i,
            o,
            a = this,
            s = e.indexOf(' ');
        return s > -1 && (r = pe.trim(e.slice(s, e.length)), e = e.slice(0, s)),
            pe.isFunction(t) ? (n = t, t = void 0) : t && 'object' == typeof t && (i = 'POST'),
        a.length > 0 && pe.ajax({
            url: e,
            type: i || 'GET',
            dataType: 'html',
            data: t
        }).done(function (e) {
            o = arguments,
                a.html(r ? pe('<div>').append(pe.parseHTML(e)).find(r) : e)
        }).always(n && function (e, t) {
            a.each(function () {
                n.apply(this, o || [
                    e.responseText,
                    t,
                    e
                ])
            })
        }),
            this
    },
        pe.each(['ajaxStart',
            'ajaxStop',
            'ajaxComplete',
            'ajaxError',
            'ajaxSuccess',
            'ajaxSend'], function (e, t) {
            pe.fn[t] = function (e) {
                return this.on(t, e)
            }
        }),
        pe.expr.filters.animated = function (e) {
            return pe.grep(pe.timers, function (t) {
                return e === t.elem
            }).length
        },
        pe.offset = {
            setOffset: function (e, t, n) {
                var r,
                    i,
                    o,
                    a,
                    s,
                    u,
                    l,
                    c = pe.css(e, 'position'),
                    f = pe(e),
                    d = {};
                'static' === c && (e.style.position = 'relative'),
                    s = f.offset(),
                    o = pe.css(e, 'top'),
                    u = pe.css(e, 'left'),
                    l = ('absolute' === c || 'fixed' === c) && pe.inArray('auto', [
                        o,
                        u
                    ]) > -1,
                    l ? (r = f.position(), a = r.top, i = r.left) : (a = parseFloat(o) || 0, i = parseFloat(u) || 0),
                pe.isFunction(t) && (t = t.call(e, n, pe.extend({}, s))),
                null != t.top && (d.top = t.top - s.top + a),
                null != t.left && (d.left = t.left - s.left + i),
                    'using' in t ? t.using.call(e, d) : f.css(d)
            }
        },
        pe.fn.extend({
            offset: function (e) {
                if (arguments.length) return void 0 === e ? this : this.each(function (t) {
                    pe.offset.setOffset(this, e, t)
                });
                var t,
                    n,
                    r = {
                        top: 0,
                        left: 0
                    },
                    i = this[0],
                    o = i && i.ownerDocument;
                if (o) return t = o.documentElement,
                    pe.contains(t, i) ? ('undefined' != typeof i.getBoundingClientRect && (r = i.getBoundingClientRect()), n = te(o), {
                        top: r.top + (n.pageYOffset || t.scrollTop) - (t.clientTop || 0),
                        left: r.left + (n.pageXOffset || t.scrollLeft) - (t.clientLeft || 0)
                    }) : r
            },
            position: function () {
                if (this[0]) {
                    var e,
                        t,
                        n = {
                            top: 0,
                            left: 0
                        },
                        r = this[0];
                    return 'fixed' === pe.css(r, 'position') ? t = r.getBoundingClientRect() : (e = this.offsetParent(), t = this.offset(), pe.nodeName(e[0], 'html') || (n = e.offset()), n.top += pe.css(e[0], 'borderTopWidth', !0), n.left += pe.css(e[0], 'borderLeftWidth', !0)),
                        {
                            top: t.top - n.top - pe.css(r, 'marginTop', !0),
                            left: t.left - n.left - pe.css(r, 'marginLeft', !0)
                        }
                }
            },
            offsetParent: function () {
                return this.map(function () {
                    for (var e = this.offsetParent; e && !pe.nodeName(e, 'html') && 'static' === pe.css(e, 'position');) e = e.offsetParent;
                    return e || pt
                })
            }
        }),
        pe.each({
            scrollLeft: 'pageXOffset',
            scrollTop: 'pageYOffset'
        }, function (e, t) {
            var n = /Y/.test(t);
            pe.fn[e] = function (r) {
                return Pe(this, function (e, r, i) {
                    var o = te(e);
                    return void 0 === i ? o ? t in o ? o[t] : o.document.documentElement[r] : e[r] : void (o ? o.scrollTo(n ? pe(o).scrollLeft() : i, n ? i : pe(o).scrollTop()) : e[r] = i)
                }, e, r, arguments.length, null)
            }
        }),
        pe.each(['top',
            'left'], function (e, t) {
            pe.cssHooks[t] = L(fe.pixelPosition, function (e, n) {
                if (n) return n = gt(e, t),
                    ft.test(n) ? pe(e).position() [t] + 'px' : n
            })
        }),
        pe.each({
            Height: 'height',
            Width: 'width'
        }, function (e, t) {
            pe.each({
                padding: 'inner' + e,
                content: t,
                '': 'outer' + e
            }, function (n, r) {
                pe.fn[r] = function (r, i) {
                    var o = arguments.length && (n || 'boolean' != typeof r),
                        a = n || (r === !0 || i === !0 ? 'margin' : 'border');
                    return Pe(this, function (t, n, r) {
                        var i;
                        return pe.isWindow(t) ? t.document.documentElement['client' + e] : 9 === t.nodeType ? (i = t.documentElement, Math.max(t.body['scroll' + e], i['scroll' + e], t.body['offset' + e], i['offset' + e], i['client' + e])) : void 0 === r ? pe.css(t, n, a) : pe.style(t, n, r, a)
                    }, t, o ? r : void 0, o, null)
                }
            })
        }),
        pe.fn.extend({
            bind: function (e, t, n) {
                return this.on(e, null, t, n)
            },
            unbind: function (e, t) {
                return this.off(e, null, t)
            },
            delegate: function (e, t, n, r) {
                return this.on(t, e, n, r)
            },
            undelegate: function (e, t, n) {
                return 1 === arguments.length ? this.off(e, '**') : this.off(t, e || '**', n)
            }
        }),
        pe.fn.size = function () {
            return this.length
        },
        pe.fn.andSelf = pe.fn.addBack,
        layui.define(function (e) {
            layui.$ = pe,
                e('jquery', pe)
        }),
        pe
});
!function (e, t) {
    'use strict';
    var i,
        n,
        a = e.layui && layui.define,
        o = {
            getPath: function () {
                var e = document.currentScript ? document.currentScript.src : function () {
                    for (var e, t = document.scripts, i = t.length - 1, n = i; n > 0; n--) if ('interactive' === t[n].readyState) {
                        e = t[n].src;
                        break
                    }
                    return e || t[i].src
                }();
                return e.substring(0, e.lastIndexOf('/') + 1)
            }(),
            config: {},
            end: {},
            minIndex: 0,
            minLeft: [],
            btn: [
                '&#x786E;&#x5B9A;',
                '&#x53D6;&#x6D88;'
            ],
            type: [
                'dialog',
                'page',
                'iframe',
                'loading',
                'tips'
            ],
            getStyle: function (t, i) {
                var n = t.currentStyle ? t.currentStyle : e.getComputedStyle(t, null);
                return n[n.getPropertyValue ? 'getPropertyValue' : 'getAttribute'](i)
            },
            link: function (t, i, n) {
                if (r.path) {
                    var a = document.getElementsByTagName('head') [0],
                        s = document.createElement('link');
                    'string' == typeof i && (n = i);
                    var l = (n || t).replace(/\.|\//g, ''),
                        f = 'layuicss-' + l,
                        c = 0;
                    s.rel = 'stylesheet',
                        s.href = r.path + t,
                        s.id = f,
                    document.getElementById(f) || a.appendChild(s),
                    'function' == typeof i && !function u() {
                        return ++c > 80 ? e.console && console.error('layer.css: Invalid') : void (1989 === parseInt(o.getStyle(document.getElementById(f), 'width')) ? i() : setTimeout(u, 100))
                    }()
                }
            }
        },
        r = {
            v: '3.1.1',
            ie: function () {
                var t = navigator.userAgent.toLowerCase();
                return !!(e.ActiveXObject || 'ActiveXObject' in e) && ((t.match(/msie\s(\d+)/) || []) [1] || '11')
            }(),
            index: e.layer && e.layer.v ? 100000 : 0,
            path: o.getPath,
            config: function (e, t) {
                return e = e || {},
                    r.cache = o.config = i.extend({}, o.config, e),
                    r.path = o.config.path || r.path,
                'string' == typeof e.extend && (e.extend = [
                    e.extend
                ]),
                o.config.path && r.ready(),
                    e.extend ? (a ? layui.addcss('modules/layer/' + e.extend) : o.link('theme/' + e.extend), this) : this
            },
            ready: function (e) {
                var t = 'layer',
                    i = '',
                    n = (a ? 'modules/layer/' : 'theme/') + 'default/layer.css?v=' + r.v + i;
                return a ? layui.addcss(n, e, t) : o.link(n, e, t),
                    this
            },
            alert: function (e, t, n) {
                var a = 'function' == typeof t;
                return a && (n = t),
                    r.open(i.extend({
                        content: e,
                        yes: n
                    }, a ? {}
                        : t))
            },
            confirm: function (e, t, n, a) {
                var s = 'function' == typeof t;
                return s && (a = n, n = t),
                    r.open(i.extend({
                        content: e,
                        btn: o.btn,
                        yes: n,
                        btn2: a
                    }, s ? {}
                        : t))
            },
            msg: function (e, n, a) {
                var s = 'function' == typeof n,
                    f = o.config.skin,
                    c = (f ? f + ' ' + f + '-msg' : '') || 'layui-layer-msg',
                    u = l.anim.length - 1;
                return s && (a = n),
                    r.open(i.extend({
                        content: e,
                        time: 3000,
                        shade: !1,
                        skin: c,
                        title: !1,
                        closeBtn: !1,
                        btn: !1,
                        resize: !1,
                        end: a
                    }, s && !o.config.skin ? {
                            skin: c + ' layui-layer-hui',
                            anim: u
                        }
                        : function () {
                            return n = n || {},
                            (n.icon === -1 || n.icon === t && !o.config.skin) && (n.skin = c + ' ' + (n.skin || 'layui-layer-hui')),
                                n
                        }()))
            },
            load: function (e, t) {
                return r.open(i.extend({
                    type: 3,
                    icon: e || 0,
                    resize: !1,
                    shade: 0.01
                }, t))
            },
            tips: function (e, t, n) {
                return r.open(i.extend({
                    type: 4,
                    content: [
                        e,
                        t
                    ],
                    closeBtn: !1,
                    time: 3000,
                    shade: !1,
                    resize: !1,
                    fixed: !1,
                    maxWidth: 210
                }, n))
            }
        },
        s = function (e) {
            var t = this;
            t.index = ++r.index,
                t.config = i.extend({}, t.config, o.config, e),
                document.body ? t.creat() : setTimeout(function () {
                    t.creat()
                }, 30)
        };
    s.pt = s.prototype;
    var l = [
        'layui-layer',
        '.layui-layer-title',
        '.layui-layer-main',
        '.layui-layer-dialog',
        'layui-layer-iframe',
        'layui-layer-content',
        'layui-layer-btn',
        'layui-layer-close'
    ];
    l.anim = [
        'layer-anim-00',
        'layer-anim-01',
        'layer-anim-02',
        'layer-anim-03',
        'layer-anim-04',
        'layer-anim-05',
        'layer-anim-06'
    ],
        s.pt.config = {
            type: 0,
            shade: 0.3,
            fixed: !0,
            move: l[1],
            title: '&#x4FE1;&#x606F;',
            offset: 'auto',
            area: 'auto',
            closeBtn: 1,
            time: 0,
            zIndex: 19891014,
            maxWidth: 360,
            anim: 0,
            isOutAnim: !0,
            icon: -1,
            moveType: 1,
            resize: !0,
            scrollbar: !0,
            tips: 2
        },
        s.pt.vessel = function (e, t) {
            var n = this,
                a = n.index,
                r = n.config,
                s = r.zIndex + a,
                f = 'object' == typeof r.title,
                c = r.maxmin && (1 === r.type || 2 === r.type),
                u = r.title ? '<div class="layui-layer-title" style="' + (f ? r.title[1] : '') + '">' + (f ? r.title[0] : r.title) + '</div>' : '';
            return r.zIndex = s,
                t([r.shade ? '<div class="layui-layer-shade" id="layui-layer-shade' + a + '" times="' + a + '" style="' + ('z-index:' + (s - 1) + '; ') + '"></div>' : '',
                    '<div class="' + l[0] + (' layui-layer-' + o.type[r.type]) + (0 != r.type && 2 != r.type || r.shade ? '' : ' layui-layer-border') + ' ' + (r.skin || '') + '" id="' + l[0] + a + '" type="' + o.type[r.type] + '" times="' + a + '" showtime="' + r.time + '" conType="' + (e ? 'object' : 'string') + '" style="z-index: ' + s + '; width:' + r.area[0] + ';height:' + r.area[1] + (r.fixed ? '' : ';position:absolute;') + '">' + (e && 2 != r.type ? '' : u) + '<div id="' + (r.id || '') + '" class="layui-layer-content' + (0 == r.type && r.icon !== -1 ? ' layui-layer-padding' : '') + (3 == r.type ? ' layui-layer-loading' + r.icon : '') + '">' + (0 == r.type && r.icon !== -1 ? '<i class="layui-layer-ico layui-layer-ico' + r.icon + '"></i>' : '') + (1 == r.type && e ? '' : r.content || '') + '</div><span class="layui-layer-setwin">' + function () {
                        var e = c ? '<a class="layui-layer-min" href="javascript:;"><cite></cite></a><a class="layui-layer-ico layui-layer-max" href="javascript:;"></a>' : '';
                        return r.closeBtn && (e += '<a class="layui-layer-ico ' + l[7] + ' ' + l[7] + (r.title ? r.closeBtn : 4 == r.type ? '1' : '2') + '" href="javascript:;"></a>'),
                            e
                    }() + '</span>' + (r.btn ? function () {
                        var e = '';
                        'string' == typeof r.btn && (r.btn = [
                            r.btn
                        ]);
                        for (var t = 0, i = r.btn.length; t < i; t++) e += '<a class="' + l[6] + t + '">' + r.btn[t] + '</a>';
                        return '<div class="' + l[6] + ' layui-layer-btn-' + (r.btnAlign || '') + '">' + e + '</div>'
                    }() : '') + (r.resize ? '<span class="layui-layer-resize"></span>' : '') + '</div>'], u, i('<div class="layui-layer-move"></div>')),
                n
        },
        s.pt.creat = function () {
            var e = this,
                t = e.config,
                a = e.index,
                s = t.content,
                f = 'object' == typeof s,
                c = i('body');
            if (!t.id || !i('#' + t.id) [0]) {
                switch ('string' == typeof t.area && (t.area = 'auto' === t.area ? [
                    '',
                    ''
                ] : [
                    t.area,
                    ''
                ]), t.shift && (t.anim = t.shift), 6 == r.ie && (t.fixed = !1), t.type) {
                    case 0:
                        t.btn = 'btn' in t ? t.btn : o.btn[0],
                            r.closeAll('dialog');
                        break;
                    case 2:
                        var s = t.content = f ? t.content : [
                            t.content || '',
                            'auto'
                        ];
                        t.content = '<iframe scrolling="' + (t.content[1] || 'auto') + '" allowtransparency="true" id="' + l[4] + a + '" name="' + l[4] + a + '" onload="this.className=\'\';" class="layui-layer-load" frameborder="0" src="' + t.content[0] + '"></iframe>';
                        break;
                    case 3:
                        delete t.title,
                            delete t.closeBtn,
                        t.icon === -1 && 0 === t.icon,
                            r.closeAll('loading');
                        break;
                    case 4:
                        f || (t.content = [
                            t.content,
                            'body'
                        ]),
                            t.follow = t.content[1],
                            t.content = t.content[0] + '<i class="layui-layer-TipsG"></i>',
                            delete t.title,
                            t.tips = 'object' == typeof t.tips ? t.tips : [
                                t.tips,
                                !0
                            ],
                        t.tipsMore || r.closeAll('tips')
                }
                if (e.vessel(f, function (n, r, u) {
                    c.append(n[0]),
                        f ? function () {
                            2 == t.type || 4 == t.type ? function () {
                                i('body').append(n[1])
                            }() : function () {
                                s.parents('.' + l[0]) [0] || (s.data('display', s.css('display')).show().addClass('layui-layer-wrap').wrap(n[1]), i('#' + l[0] + a).find('.' + l[5]).before(r))
                            }()
                        }() : c.append(n[1]),
                    i('.layui-layer-move') [0] || c.append(o.moveElem = u),
                        e.layero = i('#' + l[0] + a),
                    t.scrollbar || l.html.css('overflow', 'hidden').attr('layer-full', a)
                }).auto(a), i('#layui-layer-shade' + e.index).css({
                    'background-color': t.shade[1] || '#000',
                    opacity: t.shade[0] || t.shade
                }), 2 == t.type && 6 == r.ie && e.layero.find('iframe').attr('src', s[0]), 4 == t.type ? e.tips() : e.offset(), t.fixed && n.on('resize', function () {
                    e.offset(),
                    (/^\d+%$/.test(t.area[0]) || /^\d+%$/.test(t.area[1])) && e.auto(a),
                    4 == t.type && e.tips()
                }), t.time <= 0 || setTimeout(function () {
                    r.close(e.index)
                }, t.time), e.move().callback(), l.anim[t.anim]) {
                    var u = 'layer-anim ' + l.anim[t.anim];
                    e.layero.addClass(u).one('webkitAnimationEnd mozAnimationEnd MSAnimationEnd oanimationend animationend', function () {
                        i(this).removeClass(u)
                    })
                }
                t.isOutAnim && e.layero.data('isOutAnim', !0)
            }
        },
        s.pt.auto = function (e) {
            var t = this,
                a = t.config,
                o = i('#' + l[0] + e);
            '' === a.area[0] && a.maxWidth > 0 && (r.ie && r.ie < 8 && a.btn && o.width(o.innerWidth()), o.outerWidth() > a.maxWidth && o.width(a.maxWidth));
            var s = [
                    o.innerWidth(),
                    o.innerHeight()
                ],
                f = o.find(l[1]).outerHeight() || 0,
                c = o.find('.' + l[6]).outerHeight() || 0,
                u = function (e) {
                    e = o.find(e),
                        e.height(s[1] - f - c - 2 * (0 | parseFloat(e.css('padding-top'))))
                };
            switch (a.type) {
                case 2:
                    u('iframe');
                    break;
                default:
                    '' === a.area[1] ? a.maxHeight > 0 && o.outerHeight() > a.maxHeight ? (s[1] = a.maxHeight, u('.' + l[5])) : a.fixed && s[1] >= n.height() && (s[1] = n.height(), u('.' + l[5])) : u('.' + l[5])
            }
            return t
        },
        s.pt.offset = function () {
            var e = this,
                t = e.config,
                i = e.layero,
                a = [
                    i.outerWidth(),
                    i.outerHeight()
                ],
                o = 'object' == typeof t.offset;
            e.offsetTop = (n.height() - a[1]) / 2,
                e.offsetLeft = (n.width() - a[0]) / 2,
                o ? (e.offsetTop = t.offset[0], e.offsetLeft = t.offset[1] || e.offsetLeft) : 'auto' !== t.offset && ('t' === t.offset ? e.offsetTop = 0 : 'r' === t.offset ? e.offsetLeft = n.width() - a[0] : 'b' === t.offset ? e.offsetTop = n.height() - a[1] : 'l' === t.offset ? e.offsetLeft = 0 : 'lt' === t.offset ? (e.offsetTop = 0, e.offsetLeft = 0) : 'lb' === t.offset ? (e.offsetTop = n.height() - a[1], e.offsetLeft = 0) : 'rt' === t.offset ? (e.offsetTop = 0, e.offsetLeft = n.width() - a[0]) : 'rb' === t.offset ? (e.offsetTop = n.height() - a[1], e.offsetLeft = n.width() - a[0]) : e.offsetTop = t.offset),
            t.fixed || (e.offsetTop = /%$/.test(e.offsetTop) ? n.height() * parseFloat(e.offsetTop) / 100 : parseFloat(e.offsetTop), e.offsetLeft = /%$/.test(e.offsetLeft) ? n.width() * parseFloat(e.offsetLeft) / 100 : parseFloat(e.offsetLeft), e.offsetTop += n.scrollTop(), e.offsetLeft += n.scrollLeft()),
            i.attr('minLeft') && (e.offsetTop = n.height() - (i.find(l[1]).outerHeight() || 0), e.offsetLeft = i.css('left')),
                i.css({
                    top: e.offsetTop,
                    left: e.offsetLeft
                })
        },
        s.pt.tips = function () {
            var e = this,
                t = e.config,
                a = e.layero,
                o = [
                    a.outerWidth(),
                    a.outerHeight()
                ],
                r = i(t.follow);
            r[0] || (r = i('body'));
            var s = {
                    width: r.outerWidth(),
                    height: r.outerHeight(),
                    top: r.offset().top,
                    left: r.offset().left
                },
                f = a.find('.layui-layer-TipsG'),
                c = t.tips[0];
            t.tips[1] || f.remove(),
                s.autoLeft = function () {
                    s.left + o[0] - n.width() > 0 ? (s.tipLeft = s.left + s.width - o[0], f.css({
                        right: 12,
                        left: 'auto'
                    })) : s.tipLeft = s.left
                },
                s.where = [
                    function () {
                        s.autoLeft(),
                            s.tipTop = s.top - o[1] - 10,
                            f.removeClass('layui-layer-TipsB').addClass('layui-layer-TipsT').css('border-right-color', t.tips[1])
                    },
                    function () {
                        s.tipLeft = s.left + s.width + 10,
                            s.tipTop = s.top,
                            f.removeClass('layui-layer-TipsL').addClass('layui-layer-TipsR').css('border-bottom-color', t.tips[1])
                    },
                    function () {
                        s.autoLeft(),
                            s.tipTop = s.top + s.height + 10,
                            f.removeClass('layui-layer-TipsT').addClass('layui-layer-TipsB').css('border-right-color', t.tips[1])
                    },
                    function () {
                        s.tipLeft = s.left - o[0] - 10,
                            s.tipTop = s.top,
                            f.removeClass('layui-layer-TipsR').addClass('layui-layer-TipsL').css('border-bottom-color', t.tips[1])
                    }
                ],
                s.where[c - 1](),
                1 === c ? s.top - (n.scrollTop() + o[1] + 16) < 0 && s.where[2]() : 2 === c ? n.width() - (s.left + s.width + o[0] + 16) > 0 || s.where[3]() : 3 === c ? s.top - n.scrollTop() + s.height + o[1] + 16 - n.height() > 0 && s.where[0]() : 4 === c && o[0] + 16 - s.left > 0 && s.where[1](),
                a.find('.' + l[5]).css({
                    'background-color': t.tips[1],
                    'padding-right': t.closeBtn ? '30px' : ''
                }),
                a.css({
                    left: s.tipLeft - (t.fixed ? n.scrollLeft() : 0),
                    top: s.tipTop - (t.fixed ? n.scrollTop() : 0)
                })
        },
        s.pt.move = function () {
            var e = this,
                t = e.config,
                a = i(document),
                s = e.layero,
                l = s.find(t.move),
                f = s.find('.layui-layer-resize'),
                c = {};
            return t.move && l.css('cursor', 'move'),
                l.on('mousedown', function (e) {
                    e.preventDefault(),
                    t.move && (c.moveStart = !0, c.offset = [
                        e.clientX - parseFloat(s.css('left')),
                        e.clientY - parseFloat(s.css('top'))
                    ], o.moveElem.css('cursor', 'move').show())
                }),
                f.on('mousedown', function (e) {
                    e.preventDefault(),
                        c.resizeStart = !0,
                        c.offset = [
                            e.clientX,
                            e.clientY
                        ],
                        c.area = [
                            s.outerWidth(),
                            s.outerHeight()
                        ],
                        o.moveElem.css('cursor', 'se-resize').show()
                }),
                a.on('mousemove', function (i) {
                    if (c.moveStart) {
                        var a = i.clientX - c.offset[0],
                            o = i.clientY - c.offset[1],
                            l = 'fixed' === s.css('position');
                        if (i.preventDefault(), c.stX = l ? 0 : n.scrollLeft(), c.stY = l ? 0 : n.scrollTop(), !t.moveOut) {
                            var f = n.width() - s.outerWidth() + c.stX,
                                u = n.height() - s.outerHeight() + c.stY;
                            a < c.stX && (a = c.stX),
                            a > f && (a = f),
                            o < c.stY && (o = c.stY),
                            o > u && (o = u)
                        }
                        s.css({
                            left: a,
                            top: o
                        })
                    }
                    if (t.resize && c.resizeStart) {
                        var a = i.clientX - c.offset[0],
                            o = i.clientY - c.offset[1];
                        i.preventDefault(),
                            r.style(e.index, {
                                width: c.area[0] + a,
                                height: c.area[1] + o
                            }),
                            c.isResize = !0,
                        t.resizing && t.resizing(s)
                    }
                }).on('mouseup', function (e) {
                    c.moveStart && (delete c.moveStart, o.moveElem.hide(), t.moveEnd && t.moveEnd(s)),
                    c.resizeStart && (delete c.resizeStart, o.moveElem.hide())
                }),
                e
        },
        s.pt.callback = function () {
            function e() {
                var e = a.cancel && a.cancel(t.index, n);
                e === !1 || r.close(t.index)
            }

            var t = this,
                n = t.layero,
                a = t.config;
            t.openLayer(),
            a.success && (2 == a.type ? n.find('iframe').on('load', function () {
                a.success(n, t.index)
            }) : a.success(n, t.index)),
            6 == r.ie && t.IE6(n),
                n.find('.' + l[6]).children('a').on('click', function () {
                    var e = i(this).index();
                    if (0 === e) a.yes ? a.yes(t.index, n) : a.btn1 ? a.btn1(t.index, n) : r.close(t.index);
                    else {
                        var o = a['btn' + (e + 1)] && a['btn' + (e + 1)](t.index, n);
                        o === !1 || r.close(t.index)
                    }
                }),
                n.find('.' + l[7]).on('click', e),
            a.shadeClose && i('#layui-layer-shade' + t.index).on('click', function () {
                r.close(t.index)
            }),
                n.find('.layui-layer-min').on('click', function () {
                    var e = a.min && a.min(n);
                    e === !1 || r.min(t.index, a)
                }),
                n.find('.layui-layer-max').on('click', function () {
                    i(this).hasClass('layui-layer-maxmin') ? (r.restore(t.index), a.restore && a.restore(n)) : (r.full(t.index, a), setTimeout(function () {
                        a.full && a.full(n)
                    }, 100))
                }),
            a.end && (o.end[t.index] = a.end)
        },
        o.reselect = function () {
            i.each(i('select'), function (e, t) {
                var n = i(this);
                n.parents('.' + l[0]) [0] || 1 == n.attr('layer') && i('.' + l[0]).length < 1 && n.removeAttr('layer').show(),
                    n = null
            })
        },
        s.pt.IE6 = function (e) {
            i('select').each(function (e, t) {
                var n = i(this);
                n.parents('.' + l[0]) [0] || 'none' === n.css('display') || n.attr({
                    layer: '1'
                }).hide(),
                    n = null
            })
        },
        s.pt.openLayer = function () {
            var e = this;
            r.zIndex = e.config.zIndex,
                r.setTop = function (e) {
                    var t = function () {
                        r.zIndex++,
                            e.css('z-index', r.zIndex + 1)
                    };
                    return r.zIndex = parseInt(e[0].style.zIndex),
                        e.on('mousedown', t),
                        r.zIndex
                }
        },
        o.record = function (e) {
            var t = [
                e.width(),
                e.height(),
                e.position().top,
                e.position().left + parseFloat(e.css('margin-left'))
            ];
            e.find('.layui-layer-max').addClass('layui-layer-maxmin'),
                e.attr({
                    area: t
                })
        },
        o.rescollbar = function (e) {
            l.html.attr('layer-full') == e && (l.html[0].style.removeProperty ? l.html[0].style.removeProperty('overflow') : l.html[0].style.removeAttribute('overflow'), l.html.removeAttr('layer-full'))
        },
        e.layer = r,
        r.getChildFrame = function (e, t) {
            return t = t || i('.' + l[4]).attr('times'),
                i('#' + l[0] + t).find('iframe').contents().find(e)
        },
        r.getFrameIndex = function (e) {
            return i('#' + e).parents('.' + l[4]).attr('times')
        },
        r.iframeAuto = function (e) {
            if (e) {
                var t = r.getChildFrame('html', e).outerHeight(),
                    n = i('#' + l[0] + e),
                    a = n.find(l[1]).outerHeight() || 0,
                    o = n.find('.' + l[6]).outerHeight() || 0;
                n.css({
                    height: t + a + o
                }),
                    n.find('iframe').css({
                        height: t
                    })
            }
        },
        r.iframeSrc = function (e, t) {
            i('#' + l[0] + e).find('iframe').attr('src', t)
        },
        r.style = function (e, t, n) {
            var a = i('#' + l[0] + e),
                r = a.find('.layui-layer-content'),
                s = a.attr('type'),
                f = a.find(l[1]).outerHeight() || 0,
                c = a.find('.' + l[6]).outerHeight() || 0;
            a.attr('minLeft');
            s !== o.type[3] && s !== o.type[4] && (n || (parseFloat(t.width) <= 260 && (t.width = 260), parseFloat(t.height) - f - c <= 64 && (t.height = 64 + f + c)), a.css(t), c = a.find('.' + l[6]).outerHeight(), s === o.type[2] ? a.find('iframe').css({
                height: parseFloat(t.height) - f - c
            }) : r.css({
                height: parseFloat(t.height) - f - c - parseFloat(r.css('padding-top')) - parseFloat(r.css('padding-bottom'))
            }))
        },
        r.min = function (e, t) {
            var a = i('#' + l[0] + e),
                s = a.find(l[1]).outerHeight() || 0,
                f = a.attr('minLeft') || 181 * o.minIndex + 'px',
                c = a.css('position');
            o.record(a),
            o.minLeft[0] && (f = o.minLeft[0], o.minLeft.shift()),
                a.attr('position', c),
                r.style(e, {
                    width: 180,
                    height: s,
                    left: f,
                    top: n.height() - s,
                    position: 'fixed',
                    overflow: 'hidden'
                }, !0),
                a.find('.layui-layer-min').hide(),
            'page' === a.attr('type') && a.find(l[4]).hide(),
                o.rescollbar(e),
            a.attr('minLeft') || o.minIndex++,
                a.attr('minLeft', f)
        },
        r.restore = function (e) {
            var t = i('#' + l[0] + e),
                n = t.attr('area').split(',');
            t.attr('type');
            r.style(e, {
                width: parseFloat(n[0]),
                height: parseFloat(n[1]),
                top: parseFloat(n[2]),
                left: parseFloat(n[3]),
                position: t.attr('position'),
                overflow: 'visible'
            }, !0),
                t.find('.layui-layer-max').removeClass('layui-layer-maxmin'),
                t.find('.layui-layer-min').show(),
            'page' === t.attr('type') && t.find(l[4]).show(),
                o.rescollbar(e)
        },
        r.full = function (e) {
            var t,
                a = i('#' + l[0] + e);
            o.record(a),
            l.html.attr('layer-full') || l.html.css('overflow', 'hidden').attr('layer-full', e),
                clearTimeout(t),
                t = setTimeout(function () {
                    var t = 'fixed' === a.css('position');
                    r.style(e, {
                        top: t ? 0 : n.scrollTop(),
                        left: t ? 0 : n.scrollLeft(),
                        width: n.width(),
                        height: n.height()
                    }, !0),
                        a.find('.layui-layer-min').hide()
                }, 100)
        },
        r.title = function (e, t) {
            var n = i('#' + l[0] + (t || r.index)).find(l[1]);
            n.html(e)
        },
        r.close = function (e) {
            var t = i('#' + l[0] + e),
                n = t.attr('type'),
                a = 'layer-anim-close';
            if (t[0]) {
                var s = 'layui-layer-wrap',
                    f = function () {
                        if (n === o.type[1] && 'object' === t.attr('conType')) {
                            t.children(':not(.' + l[5] + ')').remove();
                            for (var a = t.find('.' + s), r = 0; r < 2; r++) a.unwrap();
                            a.css('display', a.data('display')).removeClass(s)
                        } else {
                            if (n === o.type[2]) try {
                                var f = i('#' + l[4] + e) [0];
                                f.contentWindow.document.write(''),
                                    f.contentWindow.close(),
                                    t.find('.' + l[5]) [0].removeChild(f)
                            } catch (c) {
                            }
                            t[0].innerHTML = '',
                                t.remove()
                        }
                        'function' == typeof o.end[e] && o.end[e](),
                            delete o.end[e]
                    };
                t.data('isOutAnim') && t.addClass('layer-anim ' + a),
                    i('#layui-layer-moves, #layui-layer-shade' + e).remove(),
                6 == r.ie && o.reselect(),
                    o.rescollbar(e),
                t.attr('minLeft') && (o.minIndex--, o.minLeft.push(t.attr('minLeft'))),
                    r.ie && r.ie < 10 || !t.data('isOutAnim') ? f() : setTimeout(function () {
                        f()
                    }, 200)
            }
        },
        r.closeAll = function (e) {
            i.each(i('.' + l[0]), function () {
                var t = i(this),
                    n = e ? t.attr('type') === e : 1;
                n && r.close(t.attr('times')),
                    n = null
            })
        };
    var f = r.cache || {},
        c = function (e) {
            return f.skin ? ' ' + f.skin + ' ' + f.skin + '-' + e : ''
        };
    r.prompt = function (e, t) {
        var a = '';
        if (e = e || {}, 'function' == typeof e && (t = e), e.area) {
            var o = e.area;
            a = 'style="width: ' + o[0] + '; height: ' + o[1] + ';"',
                delete e.area
        }
        var s,
            l = 2 == e.formType ? '<textarea class="layui-layer-input"' + a + '></textarea>' : function () {
                return '<input type="' + (1 == e.formType ? 'password' : 'text') + '" class="layui-layer-input">'
            }(),
            f = e.success;
        return delete e.success,
            r.open(i.extend({
                type: 1,
                btn: [
                    '&#x786E;&#x5B9A;',
                    '&#x53D6;&#x6D88;'
                ],
                content: l,
                skin: 'layui-layer-prompt' + c('prompt'),
                maxWidth: n.width(),
                success: function (t) {
                    s = t.find('.layui-layer-input'),
                        s.val(e.value || '').focus(),
                    'function' == typeof f && f(t)
                },
                resize: !1,
                yes: function (i) {
                    var n = s.val();
                    '' === n ? s.focus() : n.length > (e.maxlength || 500) ? r.tips('&#x6700;&#x591A;&#x8F93;&#x5165;' + (e.maxlength || 500) + '&#x4E2A;&#x5B57;&#x6570;', s, {
                        tips: 1
                    }) : t && t(n, i, s)
                }
            }, e))
    },
        r.tab = function (e) {
            e = e || {};
            var t = e.tab || {},
                n = 'layui-this',
                a = e.success;
            return delete e.success,
                r.open(i.extend({
                    type: 1,
                    skin: 'layui-layer-tab' + c('tab'),
                    resize: !1,
                    title: function () {
                        var e = t.length,
                            i = 1,
                            a = '';
                        if (e > 0) for (a = '<span class="' + n + '">' + t[0].title + '</span>'; i < e; i++) a += '<span>' + t[i].title + '</span>';
                        return a
                    }(),
                    content: '<ul class="layui-layer-tabmain">' + function () {
                        var e = t.length,
                            i = 1,
                            a = '';
                        if (e > 0) for (a = '<li class="layui-layer-tabli ' + n + '">' + (t[0].content || 'no content') + '</li>'; i < e; i++) a += '<li class="layui-layer-tabli">' + (t[i].content || 'no  content') + '</li>';
                        return a
                    }() + '</ul>',
                    success: function (t) {
                        var o = t.find('.layui-layer-title').children(),
                            r = t.find('.layui-layer-tabmain').children();
                        o.on('mousedown', function (t) {
                            t.stopPropagation ? t.stopPropagation() : t.cancelBubble = !0;
                            var a = i(this),
                                o = a.index();
                            a.addClass(n).siblings().removeClass(n),
                                r.eq(o).show().siblings().hide(),
                            'function' == typeof e.change && e.change(o)
                        }),
                        'function' == typeof a && a(t)
                    }
                }, e))
        },
        r.photos = function (t, n, a) {
            function o(e, t, i) {
                var n = new Image;
                return n.src = e,
                    n.complete ? t(n) : (n.onload = function () {
                        n.onload = null,
                            t(n)
                    }, void (n.onerror = function (e) {
                        n.onerror = null,
                            i(e)
                    }))
            }

            var s = {};
            if (t = t || {}, t.photos) {
                var l = t.photos.constructor === Object,
                    f = l ? t.photos : {},
                    u = f.data || [],
                    d = f.start || 0;
                s.imgIndex = (0 | d) + 1,
                    t.img = t.img || 'img';
                var y = t.success;
                if (delete t.success, l) {
                    if (0 === u.length) return r.msg('&#x6CA1;&#x6709;&#x56FE;&#x7247;')
                } else {
                    var p = i(t.photos),
                        h = function () {
                            u = [],
                                p.find(t.img).each(function (e) {
                                    var t = i(this);
                                    t.attr('layer-index', e),
                                        u.push({
                                            alt: t.attr('alt'),
                                            pid: t.attr('layer-pid'),
                                            src: t.attr('layer-src') || t.attr('src'),
                                            thumb: t.attr('src')
                                        })
                                })
                        };
                    if (h(), 0 === u.length) return;
                    if (n || p.on('click', t.img, function () {
                        var e = i(this),
                            n = e.attr('layer-index');
                        r.photos(i.extend(t, {
                            photos: {
                                start: n,
                                data: u,
                                tab: t.tab
                            },
                            full: t.full
                        }), !0),
                            h()
                    }), !n) return
                }
                s.imgprev = function (e) {
                    s.imgIndex--,
                    s.imgIndex < 1 && (s.imgIndex = u.length),
                        s.tabimg(e)
                },
                    s.imgnext = function (e, t) {
                        s.imgIndex++,
                        s.imgIndex > u.length && (s.imgIndex = 1, t) || s.tabimg(e)
                    },
                    s.keyup = function (e) {
                        if (!s.end) {
                            var t = e.keyCode;
                            e.preventDefault(),
                                37 === t ? s.imgprev(!0) : 39 === t ? s.imgnext(!0) : 27 === t && r.close(s.index)
                        }
                    },
                    s.tabimg = function (e) {
                        if (!(u.length <= 1)) return f.start = s.imgIndex - 1,
                            r.close(s.index),
                            r.photos(t, !0, e)
                    },
                    s.event = function () {
                        s.bigimg.hover(function () {
                            s.imgsee.show()
                        }, function () {
                            s.imgsee.hide()
                        }),
                            s.bigimg.find('.layui-layer-imgprev').on('click', function (e) {
                                e.preventDefault(),
                                    s.imgprev()
                            }),
                            s.bigimg.find('.layui-layer-imgnext').on('click', function (e) {
                                e.preventDefault(),
                                    s.imgnext()
                            }),
                            i(document).on('keyup', s.keyup)
                    },
                    s.loadi = r.load(1, {
                        shade: !('shade' in t) && 0.9,
                        scrollbar: !1
                    }),
                    o(u[d].src, function (n) {
                        r.close(s.loadi),
                            s.index = r.open(i.extend({
                                type: 1,
                                id: 'layui-layer-photos',
                                area: function () {
                                    var a = [
                                            n.width,
                                            n.height
                                        ],
                                        o = [
                                            i(e).width() - 100,
                                            i(e).height() - 100
                                        ];
                                    if (!t.full && (a[0] > o[0] || a[1] > o[1])) {
                                        var r = [
                                            a[0] / o[0],
                                            a[1] / o[1]
                                        ];
                                        r[0] > r[1] ? (a[0] = a[0] / r[0], a[1] = a[1] / r[0]) : r[0] < r[1] && (a[0] = a[0] / r[1], a[1] = a[1] / r[1])
                                    }
                                    return [a[0] + 'px',
                                        a[1] + 'px']
                                }(),
                                title: !1,
                                shade: 0.9,
                                shadeClose: !0,
                                closeBtn: !1,
                                move: '.layui-layer-phimg img',
                                moveType: 1,
                                scrollbar: !1,
                                moveOut: !0,
                                isOutAnim: !1,
                                skin: 'layui-layer-photos' + c('photos'),
                                content: '<div class="layui-layer-phimg"><img src="' + u[d].src + '" alt="' + (u[d].alt || '') + '" layer-pid="' + u[d].pid + '"><div class="layui-layer-imgsee">' + (u.length > 1 ? '<span class="layui-layer-imguide"><a href="javascript:;" class="layui-layer-iconext layui-layer-imgprev"></a><a href="javascript:;" class="layui-layer-iconext layui-layer-imgnext"></a></span>' : '') + '<div class="layui-layer-imgbar" style="display:' + (a ? 'block' : '') + '"><span class="layui-layer-imgtit"><a href="javascript:;">' + (u[d].alt || '') + '</a><em>' + s.imgIndex + '/' + u.length + '</em></span></div></div></div>',
                                success: function (e, i) {
                                    s.bigimg = e.find('.layui-layer-phimg'),
                                        s.imgsee = e.find('.layui-layer-imguide,.layui-layer-imgbar'),
                                        s.event(e),
                                    t.tab && t.tab(u[d], e),
                                    'function' == typeof y && y(e)
                                },
                                end: function () {
                                    s.end = !0,
                                        i(document).off('keyup', s.keyup)
                                }
                            }, t))
                    }, function () {
                        r.close(s.loadi),
                            r.msg('&#x5F53;&#x524D;&#x56FE;&#x7247;&#x5730;&#x5740;&#x5F02;&#x5E38;<br>&#x662F;&#x5426;&#x7EE7;&#x7EED;&#x67E5;&#x770B;&#x4E0B;&#x4E00;&#x5F20;&#xFF1F;', {
                                time: 30000,
                                btn: [
                                    '&#x4E0B;&#x4E00;&#x5F20;',
                                    '&#x4E0D;&#x770B;&#x4E86;'
                                ],
                                yes: function () {
                                    u.length > 1 && s.imgnext(!0, !0)
                                }
                            })
                    })
            }
        },
        o.run = function (t) {
            i = t,
                n = i(e),
                l.html = i('html'),
                r.open = function (e) {
                    var t = new s(e);
                    return t.index
                }
        },
        e.layui && layui.define ? (r.ready(), layui.define('jquery', function (t) {
            r.path = layui.cache.dir,
                o.run(layui.$),
                e.layer = r,
                t('layer', r)
        })) : 'function' == typeof define && define.amd ? define(['jquery'], function () {
            return o.run(e.jQuery),
                r
        }) : function () {
            o.run(e.jQuery),
                r.ready()
        }()
}(window);
layui.define('jquery', function (t) {
    'use strict';
    var a = layui.$,
        i = (layui.hint(), layui.device()),
        e = 'element',
        l = 'layui-this',
        n = 'layui-show',
        s = function () {
            this.config = {}
        };
    s.prototype.set = function (t) {
        var i = this;
        return a.extend(!0, i.config, t),
            i
    },
        s.prototype.on = function (t, a) {
            return layui.onevent.call(this, e, t, a)
        },
        s.prototype.tabAdd = function (t, i) {
            var e = '.layui-tab-title',
                l = a('.layui-tab[lay-filter=' + t + ']'),
                n = l.children(e),
                s = n.children('.layui-tab-bar'),
                o = l.children('.layui-tab-content'),
                r = '<li lay-id="' + (i.id || '') + '"' + (i.attr ? ' lay-attr="' + i.attr + '"' : '') + '>' + (i.title || 'unnaming') + '</li>';
            return s[0] ? s.before(r) : n.append(r),
                o.append('<div class="layui-tab-item">' + (i.content || '') + '</div>'),
                f.hideTabMore(!0),
                f.tabAuto(),
                this
        },
        s.prototype.tabDelete = function (t, i) {
            var e = '.layui-tab-title',
                l = a('.layui-tab[lay-filter=' + t + ']'),
                n = l.children(e),
                s = n.find('>li[lay-id="' + i + '"]');
            return f.tabDelete(null, s),
                this
        },
        s.prototype.tabChange = function (t, i) {
            var e = '.layui-tab-title',
                l = a('.layui-tab[lay-filter=' + t + ']'),
                n = l.children(e),
                s = n.find('>li[lay-id="' + i + '"]');
            return f.tabClick.call(s[0], null, null, s),
                this
        },
        s.prototype.tab = function (t) {
            t = t || {},
                b.on('click', t.headerElem, function (i) {
                    var e = a(this).index();
                    f.tabClick.call(this, i, e, null, t)
                })
        },
        s.prototype.progress = function (t, i) {
            var e = 'layui-progress',
                l = a('.' + e + '[lay-filter=' + t + ']'),
                n = l.find('.' + e + '-bar'),
                s = n.find('.' + e + '-text');
            return n.css('width', i),
                s.text(i),
                this
        };
    var o = '.layui-nav',
        r = 'layui-nav-item',
        c = 'layui-nav-bar',
        u = 'layui-nav-tree',
        d = 'layui-nav-child',
        y = 'layui-nav-more',
        h = 'layui-anim layui-anim-upbit',
        f = {
            tabClick: function (t, i, s, o) {
                o = o || {};
                var r = s || a(this),
                    i = i || r.parent().children('li').index(r),
                    c = o.headerElem ? r.parent() : r.parents('.layui-tab').eq(0),
                    u = o.bodyElem ? a(o.bodyElem) : c.children('.layui-tab-content').children('.layui-tab-item'),
                    d = r.find('a'),
                    y = c.attr('lay-filter');
                'javascript:;' !== d.attr('href') && '_blank' === d.attr('target') || (r.addClass(l).siblings().removeClass(l), u.eq(i).addClass(n).siblings().removeClass(n)),
                    layui.event.call(this, e, 'tab(' + y + ')', {
                        elem: c,
                        index: i
                    })
            },
            tabDelete: function (t, i) {
                var n = i || a(this).parent(),
                    s = n.index(),
                    o = n.parents('.layui-tab').eq(0),
                    r = o.children('.layui-tab-content').children('.layui-tab-item'),
                    c = o.attr('lay-filter');
                n.hasClass(l) && (n.next() [0] ? f.tabClick.call(n.next() [0], null, s + 1) : n.prev() [0] && f.tabClick.call(n.prev() [0], null, s - 1)),
                    n.remove(),
                    r.eq(s).remove(),
                    setTimeout(function () {
                        f.tabAuto()
                    }, 50),
                    layui.event.call(this, e, 'tabDelete(' + c + ')', {
                        elem: o,
                        index: s
                    })
            },
            tabAuto: function () {
                var t = 'layui-tab-more',
                    e = 'layui-tab-bar',
                    l = 'layui-tab-close',
                    n = this;
                a('.layui-tab').each(function () {
                    var s = a(this),
                        o = s.children('.layui-tab-title'),
                        r = (s.children('.layui-tab-content').children('.layui-tab-item'), 'lay-stope="tabmore"'),
                        c = a('<span class="layui-unselect layui-tab-bar" ' + r + '><i ' + r + ' class="layui-icon">&#xe61a;</i></span>');
                    if (n === window && 8 != i.ie && f.hideTabMore(!0), s.attr('lay-allowClose') && o.find('li').each(function () {
                        var t = a(this);
                        if (!t.find('.' + l) [0]) {
                            var i = a('<i class="layui-icon layui-unselect ' + l + '">&#x1006;</i>');
                            i.on('click', f.tabDelete),
                                t.append(i)
                        }
                    }), 'string' != typeof s.attr('lay-unauto')) if (o.prop('scrollWidth') > o.outerWidth() + 1) {
                        if (o.find('.' + e) [0]) return;
                        o.append(c),
                            s.attr('overflow', ''),
                            c.on('click', function (a) {
                                o[this.title ? 'removeClass' : 'addClass'](t),
                                    this.title = this.title ? '' : '收缩'
                            })
                    } else o.find('.' + e).remove(),
                        s.removeAttr('overflow')
                })
            },
            hideTabMore: function (t) {
                var i = a('.layui-tab-title');
                t !== !0 && 'tabmore' === a(t.target).attr('lay-stope') || (i.removeClass('layui-tab-more'), i.find('.layui-tab-bar').attr('title', ''))
            },
            clickThis: function () {
                var t = a(this),
                    i = t.parents(o),
                    n = i.attr('lay-filter'),
                    s = t.parent(),
                    c = t.siblings('.' + d),
                    y = 'string' == typeof s.attr('lay-unselect');
                'javascript:;' !== t.attr('href') && '_blank' === t.attr('target') || y || c[0] || (i.find('.' + l).removeClass(l), s.addClass(l)),
                i.hasClass(u) && (c.removeClass(h), c[0] && (s['none' === c.css('display') ? 'addClass' : 'removeClass'](r + 'ed'), 'all' === i.attr('lay-shrink') && s.siblings().removeClass(r + 'ed'))),
                    layui.event.call(this, e, 'nav(' + n + ')', t)
            },
            collapse: function () {
                var t = a(this),
                    i = t.find('.layui-colla-icon'),
                    l = t.siblings('.layui-colla-content'),
                    s = t.parents('.layui-collapse').eq(0),
                    o = s.attr('lay-filter'),
                    r = 'none' === l.css('display');
                if ('string' == typeof s.attr('lay-accordion')) {
                    var c = s.children('.layui-colla-item').children('.' + n);
                    c.siblings('.layui-colla-title').children('.layui-colla-icon').html('&#xe602;'),
                        c.removeClass(n)
                }
                l[r ? 'addClass' : 'removeClass'](n),
                    i.html(r ? '&#xe61a;' : '&#xe602;'),
                    layui.event.call(this, e, 'collapse(' + o + ')', {
                        title: t,
                        content: l,
                        show: r
                    })
            }
        };
    s.prototype.init = function (t, e) {
        var l = function () {
                return e ? '[lay-filter="' + e + '"]' : ''
            }(),
            s = {
                tab: function () {
                    f.tabAuto.call({})
                },
                nav: function () {
                    var t = 200,
                        e = {},
                        s = {},
                        p = {},
                        b = function (l, o, r) {
                            var c = a(this),
                                f = c.find('.' + d);
                            o.hasClass(u) ? l.css({
                                top: c.position().top,
                                height: c.children('a').outerHeight(),
                                opacity: 1
                            }) : (f.addClass(h), l.css({
                                left: c.position().left + parseFloat(c.css('marginLeft')),
                                top: c.position().top + c.height() - l.height()
                            }), e[r] = setTimeout(function () {
                                l.css({
                                    width: c.width(),
                                    opacity: 1
                                })
                            }, i.ie && i.ie < 10 ? 0 : t), clearTimeout(p[r]), 'block' === f.css('display') && clearTimeout(s[r]), s[r] = setTimeout(function () {
                                f.addClass(n),
                                    c.find('.' + y).addClass(y + 'd')
                            }, 300))
                        };
                    a(o + l).each(function (i) {
                        var l = a(this),
                            o = a('<span class="' + c + '"></span>'),
                            h = l.find('.' + r);
                        l.find('.' + c) [0] || (l.append(o), h.on('mouseenter', function () {
                            b.call(this, o, l, i)
                        }).on('mouseleave', function () {
                            l.hasClass(u) || (clearTimeout(s[i]), s[i] = setTimeout(function () {
                                l.find('.' + d).removeClass(n),
                                    l.find('.' + y).removeClass(y + 'd')
                            }, 300))
                        }), l.on('mouseleave', function () {
                            clearTimeout(e[i]),
                                p[i] = setTimeout(function () {
                                    l.hasClass(u) ? o.css({
                                        height: 0,
                                        top: o.position().top + o.height() / 2,
                                        opacity: 0
                                    }) : o.css({
                                        width: 0,
                                        left: o.position().left + o.width() / 2,
                                        opacity: 0
                                    })
                                }, t)
                        })),
                            h.find('a').each(function () {
                                var t = a(this),
                                    i = (t.parent(), t.siblings('.' + d));
                                i[0] && !t.children('.' + y) [0] && t.append('<span class="' + y + '"></span>'),
                                    t.off('click', f.clickThis).on('click', f.clickThis)
                            })
                    })
                },
                breadcrumb: function () {
                    var t = '.layui-breadcrumb';
                    a(t + l).each(function () {
                        var t = a(this),
                            i = 'lay-separator',
                            e = t.attr(i) || '/',
                            l = t.find('a');
                        l.next('span[' + i + ']') [0] || (l.each(function (t) {
                            t !== l.length - 1 && a(this).after('<span ' + i + '>' + e + '</span>')
                        }), t.css('visibility', 'visible'))
                    })
                },
                progress: function () {
                    var t = 'layui-progress';
                    a('.' + t + l).each(function () {
                        var i = a(this),
                            e = i.find('.layui-progress-bar'),
                            l = e.attr('lay-percent');
                        e.css('width', function () {
                            return /^.+\/.+$/.test(l) ? 100 * new Function('return ' + l)() + '%' : l
                        }()),
                        i.attr('lay-showPercent') && setTimeout(function () {
                            e.html('<span class="' + t + '-text">' + l + '</span>')
                        }, 350)
                    })
                },
                collapse: function () {
                    var t = 'layui-collapse';
                    a('.' + t + l).each(function () {
                        var t = a(this).find('.layui-colla-item');
                        t.each(function () {
                            var t = a(this),
                                i = t.find('.layui-colla-title'),
                                e = t.find('.layui-colla-content'),
                                l = 'none' === e.css('display');
                            i.find('.layui-colla-icon').remove(),
                                i.append('<i class="layui-icon layui-colla-icon">' + (l ? '&#xe602;' : '&#xe61a;') + '</i>'),
                                i.off('click', f.collapse).on('click', f.collapse)
                        })
                    })
                }
            };
        return s[t] ? s[t]() : layui.each(s, function (t, a) {
            a()
        })
    },
        s.prototype.render = s.prototype.init;
    var p = new s,
        b = a(document);
    p.render();
    var v = '.layui-tab-title li';
    b.on('click', v, f.tabClick),
        b.on('click', f.hideTabMore),
        a(window).on('resize', f.tabAuto),
        t(e, p)
});
layui.define('layer', function (e) {
    'use strict';
    var t = layui.$,
        i = layui.layer,
        n = layui.hint(),
        o = layui.device(),
        a = {
            config: {},
            set: function (e) {
                var i = this;
                return i.config = t.extend({}, i.config, e),
                    i
            },
            on: function (e, t) {
                return layui.onevent.call(this, r, e, t)
            }
        },
        l = function () {
            var e = this;
            return {
                upload: function (t) {
                    e.upload.call(e, t)
                },
                reload: function (t) {
                    e.reload.call(e, t)
                },
                config: e.config
            }
        },
        r = 'upload',
        u = 'layui-upload-file',
        c = 'layui-upload-form',
        f = 'layui-upload-iframe',
        s = 'layui-upload-choose',
        p = function (e) {
            var i = this;
            i.config = t.extend({}, i.config, a.config, e),
                i.render()
        };
    p.prototype.config = {
        accept: 'images',
        exts: '',
        auto: !0,
        bindAction: '',
        url: '',
        field: 'file',
        acceptMime: '',
        method: 'post',
        data: {},
        drag: !0,
        size: 0,
        number: 0,
        multiple: !1
    },
        p.prototype.render = function (e) {
            var i = this,
                e = i.config;
            e.elem = t(e.elem),
                e.bindAction = t(e.bindAction),
                i.file(),
                i.events()
        },
        p.prototype.file = function () {
            var e = this,
                i = e.config,
                n = e.elemFile = t(['<input class="' + u + '" type="file" accept="' + i.acceptMime + '" name="' + i.field + '"',
                    i.multiple ? ' multiple' : '',
                    '>'].join('')),
                a = i.elem.next();
            (a.hasClass(u) || a.hasClass(c)) && a.remove(),
            o.ie && o.ie < 10 && i.elem.wrap('<div class="layui-upload-wrap"></div>'),
                e.isFile() ? (e.elemFile = i.elem, i.field = i.elem[0].name) : i.elem.after(n),
            o.ie && o.ie < 10 && e.initIE()
        },
        p.prototype.initIE = function () {
            var e = this,
                i = e.config,
                n = t('<iframe id="' + f + '" class="' + f + '" name="' + f + '" frameborder="0"></iframe>'),
                o = t(['<form target="' + f + '" class="' + c + '" method="post" key="set-mine" enctype="multipart/form-data" action="' + i.url + '">',
                    '</form>'].join(''));
            t('#' + f) [0] || t('body').append(n),
            i.elem.next().hasClass(c) || (e.elemFile.wrap(o), i.elem.next('.' + c).append(function () {
                var e = [];
                return layui.each(i.data, function (t, i) {
                    i = 'function' == typeof i ? i() : i,
                        e.push('<input type="hidden" name="' + t + '" value="' + i + '">')
                }),
                    e.join('')
            }()))
        },
        p.prototype.msg = function (e) {
            return i.msg(e, {
                icon: 2,
                shift: 6
            })
        },
        p.prototype.isFile = function () {
            var e = this.config.elem[0];
            if (e) return 'input' === e.tagName.toLocaleLowerCase() && 'file' === e.type
        },
        p.prototype.preview = function (e) {
            var t = this;
            window.FileReader && layui.each(t.chooseFiles, function (t, i) {
                var n = new FileReader;
                n.readAsDataURL(i),
                    n.onload = function () {
                        e && e(t, i, this.result)
                    }
            })
        },
        p.prototype.upload = function (e, i) {
            var n,
                a = this,
                l = a.config,
                r = a.elemFile[0],
                u = function () {
                    var i = 0,
                        n = 0,
                        o = e || a.files || a.chooseFiles || r.files,
                        u = function () {
                            l.multiple && i + n === a.fileLength && 'function' == typeof l.allDone && l.allDone({
                                total: a.fileLength,
                                successful: i,
                                aborted: n
                            })
                        };
                    layui.each(o, function (e, o) {
                        var r = new FormData;
                        r.append(l.field, o),
                            layui.each(l.data, function (e, t) {
                                t = 'function' == typeof t ? t() : t,
                                    r.append(e, t)
                            }),
                            t.ajax({
                                url: l.url,
                                type: 'post',
                                data: r,
                                contentType: !1,
                                processData: !1,
                                dataType: 'json',
                                headers: l.headers || {},
                                success: function (t) {
                                    i++,
                                        d(e, t),
                                        u()
                                },
                                error: function () {
                                    n++,
                                        a.msg('请求上传接口出现异常'),
                                        m(e),
                                        u()
                                },
                                xhr: function () {
                                    var e = new XMLHttpRequest;
                                    return e.upload.addEventListener('progress', function (e) {
                                        if (e.lengthComputable) {
                                            var t = Math.floor(e.loaded / e.total * 100);
                                            'function' == typeof l.progress && l.progress(t, e)
                                        }
                                    }),
                                        e
                                }
                            })
                    })
                },
                c = function () {
                    var e = t('#' + f);
                    a.elemFile.parent().submit(),
                        clearInterval(p.timer),
                        p.timer = setInterval(function () {
                            var t,
                                i = e.contents().find('body');
                            try {
                                t = i.text()
                            } catch (n) {
                                a.msg('获取上传后的响应信息出现异常'),
                                    clearInterval(p.timer),
                                    m()
                            }
                            t && (clearInterval(p.timer), i.html(''), d(0, t))
                        }, 30)
                },
                d = function (e, t) {
                    if (a.elemFile.next('.' + s).remove(), r.value = '', 'object' != typeof t) try {
                        t = JSON.parse(t)
                    } catch (i) {
                        return t = {},
                            a.msg('请对上传接口返回有效JSON')
                    }
                    'function' == typeof l.done && l.done(t, e || 0, function (e) {
                        a.upload(e)
                    })
                },
                m = function (e) {
                    l.auto && (r.value = ''),
                    'function' == typeof l.error && l.error(e || 0, function (e) {
                        a.upload(e)
                    })
                },
                h = l.exts,
                v = function () {
                    var t = [];
                    return layui.each(e || a.chooseFiles, function (e, i) {
                        t.push(i.name)
                    }),
                        t
                }(),
                g = {
                    preview: function (e) {
                        a.preview(e)
                    },
                    upload: function (e, t) {
                        var i = {};
                        i[e] = t,
                            a.upload(i)
                    },
                    pushFile: function () {
                        return a.files = a.files || {},
                            layui.each(a.chooseFiles, function (e, t) {
                                a.files[e] = t
                            }),
                            a.files
                    },
                    resetFile: function (e, t, i) {
                        var n = new File([t], i);
                        a.files = a.files || {},
                            a.files[e] = n
                    }
                },
                y = function () {
                    /*if ('choose' !== i && !l.auto || (l.choose && l.choose(g), 'choose' !== i)) return l.before && l.before(g),
    o.ie ? o.ie > 9 ? u()  : c()  : void u()*/
                    return "choose" === t ? l.choose && l.choose(g) : ((l.before && l.before(g)) === false ? '' : a.ie ? a.ie > 9 ? u() : c() : void u());

                };
            if (v = 0 === v.length ? r.value.match(/[^\/\\]+\..+/g) || [] || '' : v, 0 !== v.length) {
                switch (l.accept) {
                    case 'file':
                        if (h && !RegExp('\\w\\.(' + h + ')$', 'i').test(escape(v))) return a.msg('选择的文件中包含不支持的格式'),
                            r.value = '';
                        break;
                    case 'video':
                        if (!RegExp('\\w\\.(' + (h || 'avi|mp4|wma|rmvb|rm|flash|3gp|flv') + ')$', 'i').test(escape(v))) return a.msg('选择的视频中包含不支持的格式'),
                            r.value = '';
                        break;
                    case 'audio':
                        if (!RegExp('\\w\\.(' + (h || 'mp3|wav|mid') + ')$', 'i').test(escape(v))) return a.msg('选择的音频中包含不支持的格式'),
                            r.value = '';
                        break;
                    default:
                        if (layui.each(v, function (e, t) {
                            RegExp('\\w\\.(' + (h || 'jpg|png|gif|bmp|jpeg$') + ')', 'i').test(escape(t)) || (n = !0)
                        }), n) return a.msg('选择的图片中包含不支持的格式'),
                            r.value = ''
                }
                if (a.fileLength = function () {
                    var t = 0,
                        i = e || a.files || a.chooseFiles || r.files;
                    return layui.each(i, function () {
                        t++
                    }),
                        t
                }(), l.number && a.fileLength > l.number) return a.msg('同时最多只能上传的数量为：' + l.number);
                if (l.size > 0 && !(o.ie && o.ie < 10)) {
                    var F;
                    if (layui.each(a.chooseFiles, function (e, t) {
                        if (t.size > 1024 * l.size) {
                            var i = l.size / 1024;
                            i = i >= 1 ? i.toFixed(2) + 'MB' : l.size + 'KB',
                                r.value = '',
                                F = i
                        }
                    }), F) return a.msg('文件不能超过' + F)
                }
                y()
            }
        },
        p.prototype.reload = function (e) {
            e = e || {},
                delete e.elem,
                delete e.bindAction;
            var i = this,
                e = i.config = t.extend({}, i.config, a.config, e),
                n = e.elem.next();
            n.attr({
                name: e.name,
                accept: e.acceptMime,
                multiple: e.multiple
            })
        },
        p.prototype.events = function () {
            var e = this,
                i = e.config,
                a = function (t) {
                    e.chooseFiles = {},
                        layui.each(t, function (t, i) {
                            var n = (new Date).getTime();
                            e.chooseFiles[n + '-' + t] = i
                        })
                },
                l = function (t, n) {
                    var o = e.elemFile,
                        a = t.length > 1 ? t.length + '个文件' : (t[0] || {}).name || o[0].value.match(/[^\/\\]+\..+/g) || [] || '';
                    o.next().hasClass(s) && o.next().remove(),
                        e.upload(null, 'choose'),
                    e.isFile() || i.choose || o.after('<span class="layui-inline ' + s + '">' + a + '</span>')
                };
            i.elem.off('upload.start').on('upload.start', function () {
                var o = t(this),
                    a = o.attr('lay-data');
                if (a) try {
                    a = new Function('return ' + a)(),
                        e.config = t.extend({}, i, a)
                } catch (l) {
                    n.error('Upload element property lay-data configuration item has a syntax error: ' + a)
                }
                e.config.item = o,
                    e.elemFile[0].click()
            }),
            o.ie && o.ie < 10 || i.elem.off('upload.over').on('upload.over', function () {
                var e = t(this);
                e.attr('lay-over', '')
            }).off('upload.leave').on('upload.leave', function () {
                var e = t(this);
                e.removeAttr('lay-over')
            }).off('upload.drop').on('upload.drop', function (n, o) {
                var r = t(this),
                    u = o.originalEvent.dataTransfer.files || [];
                r.removeAttr('lay-over'),
                    a(u),
                    i.auto ? e.upload(u) : l(u)
            }),
                e.elemFile.off('upload.change').on('upload.change', function () {
                    var t = this.files || [];
                    a(t),
                        i.auto ? e.upload() : l(t)
                }),
                i.bindAction.off('upload.action').on('upload.action', function () {
                    e.upload()
                }),
            i.elem.data('haveEvents') || (e.elemFile.on('change', function () {
                t(this).trigger('upload.change')
            }), i.elem.on('click', function () {
                e.isFile() || t(this).trigger('upload.start')
            }), i.drag && i.elem.on('dragover', function (e) {
                e.preventDefault(),
                    t(this).trigger('upload.over')
            }).on('dragleave', function (e) {
                t(this).trigger('upload.leave')
            }).on('drop', function (e) {
                e.preventDefault(),
                    t(this).trigger('upload.drop', e)
            }), i.bindAction.on('click', function () {
                t(this).trigger('upload.action')
            }), i.elem.data('haveEvents', !0))
        },
        a.render = function (e) {
            var t = new p(e);
            return l.call(t)
        },
        e(r, a)
});
layui.define('jquery', function (e) {
    'use strict';
    var i = layui.jquery,
        t = {
            config: {},
            index: layui.slider ? layui.slider.index + 10000 : 0,
            set: function (e) {
                var t = this;
                return t.config = i.extend({}, t.config, e),
                    t
            },
            on: function (e, i) {
                return layui.onevent.call(this, n, e, i)
            }
        },
        a = function () {
            var e = this,
                i = e.config;
            return {
                setValue: function (i, t) {
                    return e.slide('set', i, t || 0)
                },
                config: i
            }
        },
        n = 'slider',
        l = 'layui-disabled',
        s = 'layui-slider',
        r = 'layui-slider-bar',
        o = 'layui-slider-wrap',
        u = 'layui-slider-wrap-btn',
        d = 'layui-slider-tips',
        v = 'layui-slider-input',
        c = 'layui-slider-input-txt',
        m = 'layui-slider-input-btn',
        p = 'layui-slider-hover',
        f = function (e) {
            var a = this;
            a.index = ++t.index,
                a.config = i.extend({}, a.config, t.config, e),
                a.render()
        };
    f.prototype.config = {
        type: 'default',
        min: 0,
        max: 100,
        value: 0,
        step: 1,
        showstep: !1,
        tips: !0,
        input: !1,
        range: !1,
        height: 200,
        disabled: !1,
        theme: '#49a2e8'
    },
        f.prototype.render = function () {
            var e = this,
                t = e.config;
            if (t.step < 1 && (t.step = 1), t.max < t.min && (t.max = t.min + t.step), t.range) {
                t.value = 'object' == typeof t.value ? t.value : [
                    t.min,
                    t.value
                ];
                var a = Math.min(t.value[0], t.value[1]),
                    n = Math.max(t.value[0], t.value[1]);
                t.value[0] = a > t.min ? a : t.min,
                    t.value[1] = n > t.min ? n : t.min,
                    t.value[0] = t.value[0] > t.max ? t.max : t.value[0],
                    t.value[1] = t.value[1] > t.max ? t.max : t.value[1];
                var r = Math.floor((t.value[0] - t.min) / (t.max - t.min) * 100),
                    v = Math.floor((t.value[1] - t.min) / (t.max - t.min) * 100),
                    m = v - r + '%';
                r += '%',
                    v += '%'
            } else {
                'object' == typeof t.value && (t.value = Math.min.apply(null, t.value)),
                t.value < t.min && (t.value = t.min),
                t.value > t.max && (t.value = t.max);
                var m = Math.floor((t.value - t.min) / (t.max - t.min) * 100) + '%'
            }
            var p = t.disabled ? '#c2c2c2' : t.theme,
                f = '<div class="layui-slider ' + ('vertical' === t.type ? 'layui-slider-vertical' : '') + '">' + (t.tips ? '<div class="layui-slider-tips"></div>' : '') + '<div class="layui-slider-bar" style="background:' + p + '; ' + ('vertical' === t.type ? 'height' : 'width') + ':' + m + ';' + ('vertical' === t.type ? 'bottom' : 'left') + ':' + (r || 0) + ';"></div><div class="layui-slider-wrap" style="' + ('vertical' === t.type ? 'bottom' : 'left') + ':' + (r || m) + ';"><div class="layui-slider-wrap-btn" style="border: 2px solid ' + p + ';"></div></div>' + (t.range ? '<div class="layui-slider-wrap" style="' + ('vertical' === t.type ? 'bottom' : 'left') + ':' + v + ';"><div class="layui-slider-wrap-btn" style="border: 2px solid ' + p + ';"></div></div>' : '') + '</div>',
                h = i(t.elem),
                y = h.next('.' + s);
            if (y[0] && y.remove(), e.elemTemp = i(f), t.range ? (e.elemTemp.find('.' + o).eq(0).data('value', t.value[0]), e.elemTemp.find('.' + o).eq(1).data('value', t.value[1])) : e.elemTemp.find('.' + o).data('value', t.value), h.html(e.elemTemp), 'vertical' === t.type && e.elemTemp.height(t.height + 'px'), t.showstep) {
                for (var g = (t.max - t.min) / t.step, b = '', x = 1; x < g + 1; x++) {
                    var T = 100 * x / g;
                    T < 100 && (b += '<div class="layui-slider-step" style="' + ('vertical' === t.type ? 'bottom' : 'left') + ':' + T + '%"></div>')
                }
                e.elemTemp.append(b)
            }
            if (t.input && !t.range) {
                var w = i('<div class="layui-slider-input layui-input"><div class="layui-slider-input-txt"><input type="text" class="layui-input"></div><div class="layui-slider-input-btn"><i class="layui-icon layui-icon-up"></i><i class="layui-icon layui-icon-down"></i></div></div>');
                h.css('position', 'relative'),
                    h.append(w),
                    h.find('.' + c).children('input').val(t.value),
                    'vertical' === t.type ? w.css({
                        left: 0,
                        top: -48
                    }) : e.elemTemp.css('margin-right', w.outerWidth() + 15)
            }
            t.disabled ? (e.elemTemp.addClass(l), e.elemTemp.find('.' + u).addClass(l)) : e.slide(),
                e.elemTemp.find('.' + u).on('mouseover', function () {
                    var a = 'vertical' === t.type ? t.height : e.elemTemp[0].offsetWidth,
                        n = e.elemTemp.find('.' + o),
                        l = 'vertical' === t.type ? a - i(this).parent() [0].offsetTop - n.height() : i(this).parent() [0].offsetLeft,
                        s = l / a * 100,
                        r = i(this).parent().data('value'),
                        u = t.setTips ? t.setTips(r) : r;
                    e.elemTemp.find('.' + d).html(u),
                        'vertical' === t.type ? e.elemTemp.find('.' + d).css({
                            bottom: s + '%',
                            'margin-bottom': '20px',
                            display: 'inline-block'
                        }) : e.elemTemp.find('.' + d).css({
                            left: s + '%',
                            display: 'inline-block'
                        })
                }).on('mouseout', function () {
                    e.elemTemp.find('.' + d).css('display', 'none')
                })
        },
        f.prototype.slide = function (e, t, a) {
            var n = this,
                l = n.config,
                s = n.elemTemp,
                f = function () {
                    return 'vertical' === l.type ? l.height : s[0].offsetWidth
                },
                h = s.find('.' + o),
                y = s.next('.' + v),
                g = y.children('.' + c).children('input').val(),
                b = 100 / ((l.max - l.min) / Math.ceil(l.step)),
                x = function (e, i) {
                    e = Math.ceil(e) * b > 100 ? Math.ceil(e) * b : Math.round(e) * b,
                        e = e > 100 ? 100 : e,
                        h.eq(i).css('vertical' === l.type ? 'bottom' : 'left', e + '%');
                    var t = T(h[0].offsetLeft),
                        a = l.range ? T(h[1].offsetLeft) : 0;
                    'vertical' === l.type ? (s.find('.' + d).css({
                        bottom: e + '%',
                        'margin-bottom': '20px'
                    }), t = T(f() - h[0].offsetTop - h.height()), a = l.range ? T(f() - h[1].offsetTop - h.height()) : 0) : s.find('.' + d).css('left', e + '%'),
                        t = t > 100 ? 100 : t,
                        a = a > 100 ? 100 : a;
                    var n = Math.min(t, a),
                        o = Math.abs(t - a);
                    'vertical' === l.type ? s.find('.' + r).css({
                        height: o + '%',
                        bottom: n + '%'
                    }) : s.find('.' + r).css({
                        width: o + '%',
                        left: n + '%'
                    });
                    var u = l.min + Math.round((l.max - l.min) * e / 100);
                    if (g = u, y.children('.' + c).children('input').val(g), h.eq(i).data('value', u), u = l.setTips ? l.setTips(u) : u, s.find('.' + d).html(u), l.range) {
                        var v = [
                            h.eq(0).data('value'),
                            h.eq(1).data('value')
                        ];
                        v[0] > v[1] && v.reverse()
                    }
                    l.change && l.change(l.range ? v : u)
                },
                T = function (e) {
                    var i = e / f() * 100 / b,
                        t = Math.round(i) * b;
                    return e == f() && (t = Math.ceil(i) * b),
                        t
                },
                w = i(['<div class="layui-auxiliar-moving" id="LAY-slider-moving"></div'].join('')),
                M = function (e, t) {
                    var a = function () {
                        t && t(),
                            w.remove()
                    };
                    i('#LAY-slider-moving') [0] || i('body').append(w),
                        w.on('mousemove', e),
                        w.on('mouseup', a).on('mouseleave', a)
                };
            if ('set' === e) return x(t, a);
            s.find('.' + u).each(function (e) {
                var t = i(this);
                t.on('mousedown', function (i) {
                    i = i || window.event;
                    var a = t.parent() [0].offsetLeft,
                        n = i.clientX;
                    'vertical' === l.type && (a = f() - t.parent() [0].offsetTop - h.height(), n = i.clientY);
                    var r = function (i) {
                            i = i || window.event;
                            var r = a + ('vertical' === l.type ? n - i.clientY : i.clientX - n);
                            r < 0 && (r = 0),
                            r > f() && (r = f());
                            var o = r / f() * 100 / b;
                            x(o, e),
                                t.addClass(p),
                                s.find('.' + d).show(),
                                i.preventDefault()
                        },
                        o = function () {
                            t.removeClass(p),
                                s.find('.' + d).hide()
                        };
                    M(r, o)
                })
            }),
                s.on('click', function (e) {
                    var t = i('.' + u);
                    if (!t.is(event.target) && 0 === t.has(event.target).length && t.length) {
                        var a,
                            n = 'vertical' === l.type ? f() - e.clientY + i(this).offset().top : e.clientX - i(this).offset().left;
                        n < 0 && (n = 0),
                        n > f() && (n = f());
                        var s = n / f() * 100 / b;
                        a = l.range ? 'vertical' === l.type ? Math.abs(n - parseInt(i(h[0]).css('bottom'))) > Math.abs(n - parseInt(i(h[1]).css('bottom'))) ? 1 : 0 : Math.abs(n - h[0].offsetLeft) > Math.abs(n - h[1].offsetLeft) ? 1 : 0 : 0,
                            x(s, a),
                            e.preventDefault()
                    }
                }),
                y.hover(function () {
                    var e = i(this);
                    e.children('.' + m).fadeIn('fast')
                }, function () {
                    var e = i(this);
                    e.children('.' + m).fadeOut('fast')
                }),
                y.children('.' + m).children('i').each(function (e) {
                    i(this).on('click', function () {
                        g = 1 == e ? g - l.step < l.min ? l.min : Number(g) - l.step : Number(g) + l.step > l.max ? l.max : Number(g) + l.step;
                        var i = (g - l.min) / (l.max - l.min) * 100 / b;
                        x(i, 0)
                    })
                });
            var q = function () {
                var e = this.value;
                e = isNaN(e) ? 0 : e,
                    e = e < l.min ? l.min : e,
                    e = e > l.max ? l.max : e,
                    this.value = e;
                var i = (e - l.min) / (l.max - l.min) * 100 / b;
                x(i, 0)
            };
            y.children('.' + c).children('input').on('keydown', function (e) {
                13 === e.keyCode && (e.preventDefault(), q.call(this))
            }).on('change', q)
        },
        f.prototype.events = function () {
            var e = this;
            e.config
        },
        t.render = function (e) {
            var i = new f(e);
            return a.call(i)
        },
        e(n, t)
});
layui.define('jquery', function (e) {
    'use strict';
    var i = layui.jquery,
        o = {
            config: {},
            index: layui.colorpicker ? layui.colorpicker.index + 10000 : 0,
            set: function (e) {
                var o = this;
                return o.config = i.extend({}, o.config, e),
                    o
            },
            on: function (e, i) {
                return layui.onevent.call(this, 'colorpicker', e, i)
            }
        },
        r = function () {
            var e = this,
                i = e.config;
            return {
                config: i
            }
        },
        t = 'colorpicker',
        n = 'layui-show',
        l = 'layui-colorpicker',
        c = '.layui-colorpicker-main',
        a = 'layui-icon-down',
        s = 'layui-icon-close',
        f = 'layui-colorpicker-trigger-span',
        d = 'layui-colorpicker-trigger-i',
        u = 'layui-colorpicker-side',
        p = 'layui-colorpicker-side-slider',
        g = 'layui-colorpicker-basis',
        v = 'layui-colorpicker-alpha-bgcolor',
        h = 'layui-colorpicker-alpha-slider',
        m = 'layui-colorpicker-basis-cursor',
        b = 'layui-colorpicker-main-input',
        k = function (e) {
            var i = {
                    h: 0,
                    s: 0,
                    b: 0
                },
                o = Math.min(e.r, e.g, e.b),
                r = Math.max(e.r, e.g, e.b),
                t = r - o;
            return i.b = r,
                i.s = 0 != r ? 255 * t / r : 0,
                0 != i.s ? e.r == r ? i.h = (e.g - e.b) / t : e.g == r ? i.h = 2 + (e.b - e.r) / t : i.h = 4 + (e.r - e.g) / t : i.h = -1,
            r == o && (i.h = 0),
                i.h *= 60,
            i.h < 0 && (i.h += 360),
                i.s *= 100 / 255,
                i.b *= 100 / 255,
                i
        },
        y = function (e) {
            var e = e.indexOf('#') > -1 ? e.substring(1) : e;
            if (3 == e.length) {
                var i = e.split('');
                e = i[0] + i[0] + i[1] + i[1] + i[2] + i[2]
            }
            e = parseInt(e, 16);
            var o = {
                r: e >> 16,
                g: (65280 & e) >> 8,
                b: 255 & e
            };
            return k(o)
        },
        x = function (e) {
            var i = {},
                o = e.h,
                r = 255 * e.s / 100,
                t = 255 * e.b / 100;
            if (0 == r) i.r = i.g = i.b = t;
            else {
                var n = t,
                    l = (255 - r) * t / 255,
                    c = (n - l) * (o % 60) / 60;
                360 == o && (o = 0),
                    o < 60 ? (i.r = n, i.b = l, i.g = l + c) : o < 120 ? (i.g = n, i.b = l, i.r = n - c) : o < 180 ? (i.g = n, i.r = l, i.b = l + c) : o < 240 ? (i.b = n, i.r = l, i.g = n - c) : o < 300 ? (i.b = n, i.g = l, i.r = l + c) : o < 360 ? (i.r = n, i.g = l, i.b = n - c) : (i.r = 0, i.g = 0, i.b = 0)
            }
            return {
                r: Math.round(i.r),
                g: Math.round(i.g),
                b: Math.round(i.b)
            }
        },
        C = function (e) {
            var o = x(e),
                r = [
                    o.r.toString(16),
                    o.g.toString(16),
                    o.b.toString(16)
                ];
            return i.each(r, function (e, i) {
                1 == i.length && (r[e] = '0' + i)
            }),
                r.join('')
        },
        P = function (e) {
            var i = /[0-9]{1,3}/g,
                o = e.match(i) || [];
            return {
                r: o[0],
                g: o[1],
                b: o[2]
            }
        },
        B = i(window),
        w = i(document),
        D = function (e) {
            var r = this;
            r.index = ++o.index,
                r.config = i.extend({}, r.config, o.config, e),
                r.render()
        };
    D.prototype.config = {
        color: '',
        size: null,
        alpha: !1,
        format: 'hex',
        predefine: !1,
        colors: [
            '#49a2e8',
            '#5FB878',
            '#1E9FFF',
            '#FF5722',
            '#FFB800',
            '#01AAED',
            '#999',
            '#c00',
            '#ff8c00',
            '#ffd700',
            '#90ee90',
            '#00ced1',
            '#1e90ff',
            '#c71585',
            'rgb(0, 186, 189)',
            'rgb(255, 120, 0)',
            'rgb(250, 212, 0)',
            '#393D49',
            'rgba(0,0,0,.5)',
            'rgba(255, 69, 0, 0.68)',
            'rgba(144, 240, 144, 0.5)',
            'rgba(31, 147, 255, 0.73)'
        ]
    },
        D.prototype.render = function () {
            var e = this,
                o = e.config,
                r = i(['<div class="layui-unselect layui-colorpicker">',
                    '<span ' + ('rgb' == o.format && o.alpha ? 'class="layui-colorpicker-trigger-bgcolor"' : '') + '>',
                    '<span class="layui-colorpicker-trigger-span" ',
                    'lay-type="' + ('rgb' == o.format ? o.alpha ? 'rgba' : 'torgb' : '') + '" ',
                    'style="' + function () {
                        var e = '';
                        return o.color ? (e = o.color, (o.color.match(/[0-9]{1,3}/g) || []).length > 3 && (o.alpha && 'rgb' == o.format || (e = '#' + C(k(P(o.color))))), 'background: ' + e) : e
                    }() + '">',
                    '<i class="layui-icon layui-colorpicker-trigger-i ' + (o.color ? a : s) + '"></i>',
                    '</span>',
                    '</span>',
                    '</div>'].join('')),
                t = i(o.elem);
            o.size && r.addClass('layui-colorpicker-' + o.size),
                t.addClass('layui-inline').html(e.elemColorBox = r),
                e.color = e.elemColorBox.find('.' + f) [0].style.background,
                e.events()
        },
        D.prototype.renderPicker = function () {
            var e = this,
                o = e.config,
                r = e.elemColorBox[0],
                t = e.elemPicker = i(['<div id="layui-colorpicker' + e.index + '" data-index="' + e.index + '" class="layui-anim layui-anim-upbit layui-colorpicker-main">',
                    '<div class="layui-colorpicker-main-wrapper">',
                    '<div class="layui-colorpicker-basis">',
                    '<div class="layui-colorpicker-basis-white"></div>',
                    '<div class="layui-colorpicker-basis-black"></div>',
                    '<div class="layui-colorpicker-basis-cursor"></div>',
                    '</div>',
                    '<div class="layui-colorpicker-side">',
                    '<div class="layui-colorpicker-side-slider"></div>',
                    '</div>',
                    '</div>',
                    '<div class="layui-colorpicker-main-alpha ' + (o.alpha ? n : '') + '">',
                    '<div class="layui-colorpicker-alpha-bgcolor">',
                    '<div class="layui-colorpicker-alpha-slider"></div>',
                    '</div>',
                    '</div>',
                    function () {
                        if (o.predefine) {
                            var e = [
                                '<div class="layui-colorpicker-main-pre">'
                            ];
                            return layui.each(o.colors, function (i, o) {
                                e.push(['<div class="layui-colorpicker-pre' + ((o.match(/[0-9]{1,3}/g) || []).length > 3 ? ' layui-colorpicker-pre-isalpha' : '') + '">',
                                    '<div style="background:' + o + '"></div>',
                                    '</div>'].join(''))
                            }),
                                e.push('</div>'),
                                e.join('')
                        }
                        return ''
                    }(),
                    '<div class="layui-colorpicker-main-input">',
                    '<div class="layui-inline">',
                    '<input type="text" class="layui-input">',
                    '</div>',
                    '<div class="layui-btn-container">',
                    '<button class="layui-btn layui-btn-primary layui-btn-sm" colorpicker-events="clear">清空</button>',
                    '<button class="layui-btn layui-btn-sm" colorpicker-events="confirm">确定</button>',
                    '</div',
                    '</div>',
                    '</div>'].join(''));
            e.elemColorBox.find('.' + f) [0];
            i(c) [0] && i(c).data('index') == e.index ? e.removePicker(D.thisElemInd) : (e.removePicker(D.thisElemInd), i('body').append(t)),
                D.thisElemInd = e.index,
                D.thisColor = r.style.background,
                e.position(),
                e.pickerEvents()
        },
        D.prototype.removePicker = function (e) {
            var o = this;
            o.config;
            return i('#layui-colorpicker' + (e || o.index)).remove(),
                o
        },
        D.prototype.position = function () {
            var e = this,
                i = e.config,
                o = e.bindElem || e.elemColorBox[0],
                r = e.elemPicker[0],
                t = o.getBoundingClientRect(),
                n = r.offsetWidth,
                l = r.offsetHeight,
                c = function (e) {
                    return e = e ? 'scrollLeft' : 'scrollTop',
                    document.body[e] | document.documentElement[e]
                },
                a = function (e) {
                    return document.documentElement[e ? 'clientWidth' : 'clientHeight']
                },
                s = 5,
                f = t.left,
                d = t.bottom;
            f -= (n - o.offsetWidth) / 2,
                d += s,
                f + n + s > a('width') ? f = a('width') - n - s : f < s && (f = s),
            d + l + s > a() && (d = t.top > l ? t.top - l : a() - l, d -= 2 * s),
            i.position && (r.style.position = i.position),
                r.style.left = f + ('fixed' === i.position ? 0 : c(1)) + 'px',
                r.style.top = d + ('fixed' === i.position ? 0 : c()) + 'px'
        },
        D.prototype.val = function () {
            var e = this,
                i = (e.config, e.elemColorBox.find('.' + f)),
                o = e.elemPicker.find('.' + b),
                r = i[0],
                t = r.style.backgroundColor;
            if (t) {
                var n = k(P(t)),
                    l = i.attr('lay-type');
                if (e.select(n.h, n.s, n.b), 'torgb' === l && o.find('input').val(t), 'rgba' === l) {
                    var c = P(t);
                    if (3 == (t.match(/[0-9]{1,3}/g) || []).length) o.find('input').val('rgba(' + c.r + ', ' + c.g + ', ' + c.b + ', 1)'),
                        e.elemPicker.find('.' + h).css('left', 280);
                    else {
                        o.find('input').val(t);
                        var a = 280 * t.slice(t.lastIndexOf(',') + 1, t.length - 1);
                        e.elemPicker.find('.' + h).css('left', a)
                    }
                    e.elemPicker.find('.' + v) [0].style.background = 'linear-gradient(to right, rgba(' + c.r + ', ' + c.g + ', ' + c.b + ', 0), rgb(' + c.r + ', ' + c.g + ', ' + c.b + '))'
                }
            } else e.select(0, 100, 100),
                o.find('input').val(''),
                e.elemPicker.find('.' + v) [0].style.background = '',
                e.elemPicker.find('.' + h).css('left', 280)
        },
        D.prototype.side = function () {
            var e = this,
                o = e.config,
                r = e.elemColorBox.find('.' + f),
                t = r.attr('lay-type'),
                n = e.elemPicker.find('.' + u),
                l = e.elemPicker.find('.' + p),
                c = e.elemPicker.find('.' + g),
                y = e.elemPicker.find('.' + m),
                C = e.elemPicker.find('.' + v),
                w = e.elemPicker.find('.' + h),
                D = l[0].offsetTop / 180 * 360,
                E = 100 - (y[0].offsetTop + 3) / 180 * 100,
                H = (y[0].offsetLeft + 3) / 260 * 100,
                W = Math.round(w[0].offsetLeft / 280 * 100) / 100,
                j = e.elemColorBox.find('.' + d),
                F = e.elemPicker.find('.layui-colorpicker-pre').children('div'),
                L = function (i, n, l, c) {
                    e.select(i, n, l);
                    var f = x({
                        h: i,
                        s: n,
                        b: l
                    });
                    if (j.addClass(a).removeClass(s), r[0].style.background = 'rgb(' + f.r + ', ' + f.g + ', ' + f.b + ')', 'torgb' === t && e.elemPicker.find('.' + b).find('input').val('rgb(' + f.r + ', ' + f.g + ', ' + f.b + ')'), 'rgba' === t) {
                        var d = 0;
                        d = 280 * c,
                            w.css('left', d),
                            e.elemPicker.find('.' + b).find('input').val('rgba(' + f.r + ', ' + f.g + ', ' + f.b + ', ' + c + ')'),
                            r[0].style.background = 'rgba(' + f.r + ', ' + f.g + ', ' + f.b + ', ' + c + ')',
                            C[0].style.background = 'linear-gradient(to right, rgba(' + f.r + ', ' + f.g + ', ' + f.b + ', 0), rgb(' + f.r + ', ' + f.g + ', ' + f.b + '))'
                    }
                    o.change && o.change(e.elemPicker.find('.' + b).find('input').val())
                },
                M = i(['<div class="layui-auxiliar-moving" id="LAY-colorpicker-moving"></div'].join('')),
                Y = function (e) {
                    i('#LAY-colorpicker-moving') [0] || i('body').append(M),
                        M.on('mousemove', e),
                        M.on('mouseup', function () {
                            M.remove()
                        }).on('mouseleave', function () {
                            M.remove()
                        })
                };
            l.on('mousedown', function (e) {
                var i = this.offsetTop,
                    o = e.clientY,
                    r = function (e) {
                        var r = i + (e.clientY - o),
                            t = n[0].offsetHeight;
                        r < 0 && (r = 0),
                        r > t && (r = t);
                        var l = r / 180 * 360;
                        D = l,
                            L(l, H, E, W),
                            e.preventDefault()
                    };
                Y(r),
                    e.preventDefault()
            }),
                n.on('click', function (e) {
                    var o = e.clientY - i(this).offset().top;
                    o < 0 && (o = 0),
                    o > this.offsetHeight && (o = this.offsetHeight);
                    var r = o / 180 * 360;
                    D = r,
                        L(r, H, E, W),
                        e.preventDefault()
                }),
                y.on('mousedown', function (e) {
                    var i = this.offsetTop,
                        o = this.offsetLeft,
                        r = e.clientY,
                        t = e.clientX,
                        n = function (e) {
                            var n = i + (e.clientY - r),
                                l = o + (e.clientX - t),
                                a = c[0].offsetHeight - 3,
                                s = c[0].offsetWidth - 3;
                            n < -3 && (n = -3),
                            n > a && (n = a),
                            l < -3 && (l = -3),
                            l > s && (l = s);
                            var f = (l + 3) / 260 * 100,
                                d = 100 - (n + 3) / 180 * 100;
                            E = d,
                                H = f,
                                L(D, f, d, W),
                                e.preventDefault()
                        };
                    layui.stope(e),
                        Y(n),
                        e.preventDefault()
                }),
                c.on('mousedown', function (e) {
                    var o = e.clientY - i(this).offset().top - 3 + B.scrollTop(),
                        r = e.clientX - i(this).offset().left - 3 + B.scrollLeft();
                    o < -3 && (o = -3),
                    o > this.offsetHeight - 3 && (o = this.offsetHeight - 3),
                    r < -3 && (r = -3),
                    r > this.offsetWidth - 3 && (r = this.offsetWidth - 3);
                    var t = (r + 3) / 260 * 100,
                        n = 100 - (o + 3) / 180 * 100;
                    E = n,
                        H = t,
                        L(D, t, n, W),
                        e.preventDefault(),
                        y.trigger(e, 'mousedown')
                }),
                w.on('mousedown', function (e) {
                    var i = this.offsetLeft,
                        o = e.clientX,
                        r = function (e) {
                            var r = i + (e.clientX - o),
                                t = C[0].offsetWidth;
                            r < 0 && (r = 0),
                            r > t && (r = t);
                            var n = Math.round(r / 280 * 100) / 100;
                            W = n,
                                L(D, H, E, n),
                                e.preventDefault()
                        };
                    Y(r),
                        e.preventDefault()
                }),
                C.on('click', function (e) {
                    var o = e.clientX - i(this).offset().left;
                    o < 0 && (o = 0),
                    o > this.offsetWidth && (o = this.offsetWidth);
                    var r = Math.round(o / 280 * 100) / 100;
                    W = r,
                        L(D, H, E, r),
                        e.preventDefault()
                }),
                F.each(function () {
                    i(this).on('click', function () {
                        i(this).parent('.layui-colorpicker-pre').addClass('selected').siblings().removeClass('selected');
                        var e,
                            o = this.style.backgroundColor,
                            r = k(P(o)),
                            t = o.slice(o.lastIndexOf(',') + 1, o.length - 1);
                        D = r.h,
                            H = r.s,
                            E = r.b,
                        3 == (o.match(/[0-9]{1,3}/g) || []).length && (t = 1),
                            W = t,
                            e = 280 * t,
                            L(r.h, r.s, r.b, t)
                    })
                })
        },
        D.prototype.select = function (e, i, o, r) {
            var t = this,
                n = (t.config, C({
                    h: e,
                    s: 100,
                    b: 100
                })),
                l = C({
                    h: e,
                    s: i,
                    b: o
                }),
                c = e / 360 * 180,
                a = 180 - o / 100 * 180 - 3,
                s = i / 100 * 260 - 3;
            t.elemPicker.find('.' + p).css('top', c),
                t.elemPicker.find('.' + g) [0].style.background = '#' + n,
                t.elemPicker.find('.' + m).css({
                    top: a,
                    left: s
                }),
            'change' !== r && t.elemPicker.find('.' + b).find('input').val('#' + l)
        },
        D.prototype.pickerEvents = function () {
            var e = this,
                o = e.config,
                r = e.elemColorBox.find('.' + f),
                t = e.elemPicker.find('.' + b + ' input'),
                n = {
                    clear: function (i) {
                        r[0].style.background = '',
                            e.elemColorBox.find('.' + d).removeClass(a).addClass(s),
                            e.color = '',
                        o.done && o.done(''),
                            e.removePicker()
                    },
                    confirm: function (i, n) {
                        var l = t.val(),
                            c = l,
                            f = {};
                        if (l.indexOf(',') > -1) {
                            if (f = k(P(l)), e.select(f.h, f.s, f.b), r[0].style.background = c = '#' + C(f), (l.match(/[0-9]{1,3}/g) || []).length > 3 && 'rgba' === r.attr('lay-type')) {
                                var u = 280 * l.slice(l.lastIndexOf(',') + 1, l.length - 1);
                                e.elemPicker.find('.' + h).css('left', u),
                                    r[0].style.background = l,
                                    c = l
                            }
                        } else f = y(l),
                            r[0].style.background = c = '#' + C(f),
                            e.elemColorBox.find('.' + d).removeClass(s).addClass(a);
                        return 'change' === n ? (e.select(f.h, f.s, f.b, n), void (o.change && o.change(c))) : (e.color = l, o.done && o.done(l), void e.removePicker())
                    }
                };
            e.elemPicker.on('click', '*[colorpicker-events]', function () {
                var e = i(this),
                    o = e.attr('colorpicker-events');
                n[o] && n[o].call(this, e)
            }),
                t.on('keyup', function (e) {
                    var o = i(this);
                    n.confirm.call(this, o, 13 === e.keyCode ? null : 'change')
                })
        },
        D.prototype.events = function () {
            var e = this,
                o = e.config,
                r = e.elemColorBox.find('.' + f);
            e.elemColorBox.on('click', function () {
                e.renderPicker(),
                i(c) [0] && (e.val(), e.side())
            }),
            o.elem[0] && !e.elemColorBox[0].eventHandler && (w.on('click', function (o) {
                if (!i(o.target).hasClass(l) && !i(o.target).parents('.' + l) [0] && !i(o.target).hasClass(c.replace(/\./g, '')) && !i(o.target).parents(c) [0] && e.elemPicker) {
                    if (e.color) {
                        var t = k(P(e.color));
                        e.select(t.h, t.s, t.b)
                    } else e.elemColorBox.find('.' + d).removeClass(a).addClass(s);
                    r[0].style.background = e.color || '',
                        e.removePicker()
                }
            }), B.on('resize', function () {
                return !(!e.elemPicker || !i(c) [0]) && void e.position()
            }), e.elemColorBox[0].eventHandler = !0)
        },
        o.render = function (e) {
            var i = new D(e);
            return r.call(i)
        },
        e(t, o)
});
layui.define('layer', function (e) {
    'use strict';
    var t = layui.$,
        i = layui.layer,
        a = layui.hint(),
        n = layui.device(),
        l = 'form',
        r = '.layui-form',
        s = 'layui-this',
        o = 'layui-hide',
        c = 'layui-disabled',
        u = function () {
            this.config = {
                verify: {
                    required: [
                        /[\S]+/,
                        '必填项不能为空'
                    ],
                    phone: [
                        /^1\d{10}$/,
                        '请输入正确的手机号'
                    ],
                    email: [
                        /^([a-zA-Z0-9_\.\-])+\@(([a-zA-Z0-9\-])+\.)+([a-zA-Z0-9]{2,4})+$/,
                        '邮箱格式不正确'
                    ],
                    url: [
                        /(^#)|(^http(s*):\/\/[^\s]+\.[^\s]+)/,
                        '链接格式不正确'
                    ],
                    number: function (e) {
                        if (!e || isNaN(e)) return '只能填写数字'
                    },
                    date: [
                        /^(\d{4})[-\/](\d{1}|0\d{1}|1[0-2])([-\/](\d{1}|0\d{1}|[1-2][0-9]|3[0-1]))*$/,
                        '日期格式不正确'
                    ],
                    identity: [
                        /(^\d{15}$)|(^\d{17}(x|X|\d)$)/,
                        '请输入正确的身份证号'
                    ]
                }
            }
        };
    u.prototype.set = function (e) {
        var i = this;
        return t.extend(!0, i.config, e),
            i
    },
        u.prototype.verify = function (e) {
            var i = this;
            return t.extend(!0, i.config.verify, e),
                i
        },
        u.prototype.on = function (e, t) {
            return layui.onevent.call(this, l, e, t)
        },
        u.prototype.val = function (e, i) {
            var a = this,
                n = t(r + '[lay-filter="' + e + '"]');
            return n.each(function (e, a) {
                var n = t(this);
                layui.each(i, function (e, t) {
                    var i,
                        a = n.find('[name="' + e + '"]');
                    a[0] && (i = a[0].type, 'checkbox' === i ? a[0].checked = t : 'radio' === i ? a.each(function () {
                        this.value == t && (this.checked = !0)
                    }) : a.val(t))
                })
            }),
                f.render(null, e),
                a.getValue(e)
        },
        u.prototype.getValue = function (e, i) {
            i = i || t(r + '[lay-filter="' + e + '"]').eq(0);
            var a = {},
                n = {},
                l = i.find('input,select,textarea');
            return layui.each(l, function (e, t) {
                if (t.name = (t.name || '').replace(/^\s*|\s*&/, ''), t.name) {
                    if (/^.*\[\]$/.test(t.name)) {
                        var i = t.name.match(/^(.*)\[\]$/g) [0];
                        a[i] = 0 | a[i],
                            t.name = t.name.replace(/^(.*)\[\]$/, '$1[' + a[i]++ + ']')
                    }
                    /^checkbox|radio$/.test(t.type) && !t.checked || (n[t.name] = t.value)
                }
            }),
                n
        },
        u.prototype.render = function (e, i) {
            var n = this,
                u = t(r + function () {
                    return i ? '[lay-filter="' + i + '"]' : ''
                }()),
                d = {
                    select: function () {
                        var e,
                            i = '请选择',
                            a = 'layui-form-select',
                            n = 'layui-select-title',
                            r = 'layui-select-none',
                            d = '',
                            f = u.find('select'),
                            v = function (i, l) {
                                t(i.target).parent().hasClass(n) && !l || (t('.' + a).removeClass(a + 'ed ' + a + 'up'), e && d && e.val(d)),
                                    e = null
                            },
                            y = function (i, u, f) {
                                var y,
                                    p = t(this),
                                    m = i.find('.' + n),
                                    k = m.find('input'),
                                    g = i.find('dl'),
                                    x = g.children('dd'),
                                    b = this.selectedIndex;
                                if (!u) {
                                    var C = function () {
                                            var e = i.offset().top + i.outerHeight() + 5 - h.scrollTop(),
                                                t = g.outerHeight();
                                            b = p[0].selectedIndex,
                                                i.addClass(a + 'ed'),
                                                x.removeClass(o),
                                                y = null,
                                                x.eq(b).addClass(s).siblings().removeClass(s),
                                            e + t > h.height() && e >= t && i.addClass(a + 'up'),
                                                T()
                                        },
                                        w = function (e) {
                                            i.removeClass(a + 'ed ' + a + 'up'),
                                                k.blur(),
                                                y = null,
                                            e || $(k.val(), function (e) {
                                                var i = p[0].selectedIndex;
                                                e && (d = t(p[0].options[i]).html(), 0 === i && d === k.attr('placeholder') && (d = ''), k.val(d || ''))
                                            })
                                        },
                                        T = function () {
                                            var e = g.children('dd.' + s);
                                            if (e[0]) {
                                                var t = e.position().top,
                                                    i = g.height(),
                                                    a = e.height();
                                                t > i && g.scrollTop(t + g.scrollTop() - i + a - 5),
                                                t < 0 && g.scrollTop(t + g.scrollTop() - 5)
                                            }
                                        };
                                    m.on('click', function (e) {
                                        i.hasClass(a + 'ed') ? w() : (v(e, !0), C()),
                                            g.find('.' + r).remove()
                                    }),
                                        m.find('.layui-edge').on('click', function () {
                                            k.focus()
                                        }),
                                        k.on('keyup', function (e) {
                                            var t = e.keyCode;
                                            9 === t && C()
                                        }).on('keydown', function (e) {
                                            var t = e.keyCode;
                                            9 === t && w();
                                            var i = function (t, a) {
                                                var n,
                                                    l;
                                                e.preventDefault();
                                                var r = function () {
                                                    var e = g.children('dd.' + s);
                                                    if (g.children('dd.' + o) [0] && 'next' === t) {
                                                        var i = g.children('dd:not(.' + o + ',.' + c + ')'),
                                                            n = i.eq(0).index();
                                                        if (n >= 0 && n < e.index() && !i.hasClass(s)) return i.eq(0).prev() [0] ? i.eq(0).prev() : g.children(':last')
                                                    }
                                                    return a && a[0] ? a : y && y[0] ? y : e
                                                }();
                                                return l = r[t](),
                                                    n = r[t]('dd:not(.' + o + ')'),
                                                    l[0] ? (y = r[t](), n[0] && !n.hasClass(c) || !y[0] ? (n.addClass(s).siblings().removeClass(s), void T()) : i(t, y)) : y = null
                                            };
                                            38 === t && i('prev'),
                                            40 === t && i('next'),
                                            13 === t && (e.preventDefault(), g.children('dd.' + s).trigger('click'))
                                        });
                                    var $ = function (e, i, a) {
                                            var n = 0;
                                            layui.each(x, function () {
                                                var i = t(this),
                                                    l = i.text(),
                                                    r = l.indexOf(e) === -1;
                                                ('' === e || 'blur' === a ? e !== l : r) && n++,
                                                'keyup' === a && i[r ? 'addClass' : 'removeClass'](o)
                                            });
                                            var l = n === x.length;
                                            return i(l),
                                                l
                                        },
                                        q = function (e) {
                                            var t = this.value,
                                                i = e.keyCode;
                                            return 9 !== i && 13 !== i && 37 !== i && 38 !== i && 39 !== i && 40 !== i && ($(t, function (e) {
                                                e ? g.find('.' + r) [0] || g.append('<p class="' + r + '">无匹配项</p>') : g.find('.' + r).remove()
                                            }, 'keyup'), '' === t && g.find('.' + r).remove(), void T())
                                        };
                                    f && k.on('keyup', q).on('blur', function (i) {
                                        var a = p[0].selectedIndex;
                                        e = k,
                                            d = t(p[0].options[a]).html(),
                                        0 === a && d === k.attr('placeholder') && (d = ''),
                                            setTimeout(function () {
                                                $(k.val(), function (e) {
                                                    d || k.val('')
                                                }, 'blur')
                                            }, 200)
                                    }),
                                        x.on('click', function () {
                                            var e = t(this),
                                                a = e.attr('lay-value'),
                                                n = p.attr('lay-filter');
                                            return !e.hasClass(c) && (e.hasClass('layui-select-tips') ? k.val('') : (k.val(e.text()), e.addClass(s)), e.siblings().removeClass(s), p.val(a).removeClass('layui-form-danger'), layui.event.call(this, l, 'select(' + n + ')', {
                                                elem: p[0],
                                                value: a,
                                                othis: i
                                            }), w(!0), !1)
                                        }),
                                        i.find('dl>dt').on('click', function (e) {
                                            return !1
                                        }),
                                        t(document).off('click', v).on('click', v)
                                }
                            };
                        f.each(function (e, l) {
                            var r = t(this),
                                o = r.next('.' + a),
                                u = this.disabled,
                                d = l.value,
                                f = t(l.options[l.selectedIndex]),
                                v = l.options[0];
                            if ('string' == typeof r.attr('lay-ignore')) return r.show();
                            var h = 'string' == typeof r.attr('lay-search'),
                                p = v ? v.value ? i : v.innerHTML || i : i,
                                m = t(['<div class="' + (h ? '' : 'layui-unselect ') + a,
                                    (u ? ' layui-select-disabled' : '') + '">',
                                    '<div class="' + n + '">',
                                    '<input type="text" placeholder="' + p + '" ' + ('value="' + (d ? f.html() : '') + '"') + (h ? '' : ' readonly') + ' class="layui-input' + (h ? '' : ' layui-unselect') + (u ? ' ' + c : '') + '">',
                                    '<i class="layui-edge"></i></div>',
                                    '<dl class="layui-anim layui-anim-upbit' + (r.find('optgroup') [0] ? ' layui-select-group' : '') + '">',
                                    function (e) {
                                        var t = [];
                                        return layui.each(e, function (e, a) {
                                            0 !== e || a.value ? 'optgroup' === a.tagName.toLowerCase() ? t.push('<dt>' + a.label + '</dt>') : t.push('<dd lay-value="' + a.value + '" class="' + (d === a.value ? s : '') + (a.disabled ? ' ' + c : '') + '">' + a.innerHTML + '</dd>') : t.push('<dd lay-value="" class="layui-select-tips">' + (a.innerHTML || i) + '</dd>')
                                        }),
                                        0 === t.length && t.push('<dd lay-value="" class="' + c + '">没有选项</dd>'),
                                            t.join('')
                                    }(r.find('*')) + '</dl>',
                                    '</div>'].join(''));
                            o[0] && o.remove(),
                                r.after(m),
                                y.call(this, m, u, h)
                        })
                    },
                    checkbox: function () {
                        var e = {
                                checkbox: [
                                    'layui-form-checkbox',
                                    'layui-form-checked',
                                    'checkbox'
                                ],
                                _switch: [
                                    'layui-form-switch',
                                    'layui-form-onswitch',
                                    'switch'
                                ]
                            },
                            i = u.find('input[type=checkbox]'),
                            a = function (e, i) {
                                var a = t(this);
                                e.on('click', function () {
                                    var t = a.attr('lay-filter'),
                                        n = (a.attr('lay-text') || '').split('|');
                                    a[0].disabled || (a[0].checked ? (a[0].checked = !1, e.removeClass(i[1]).find('em').text(n[1])) : (a[0].checked = !0, e.addClass(i[1]).find('em').text(n[0])), layui.event.call(a[0], l, i[2] + '(' + t + ')', {
                                        elem: a[0],
                                        value: a[0].value,
                                        othis: e
                                    }))
                                })
                            };
                        i.each(function (i, n) {
                            var l = t(this),
                                r = l.attr('lay-skin'),
                                s = (l.attr('lay-text') || '').split('|'),
                                o = this.disabled;
                            'switch' === r && (r = '_' + r);
                            var u = e[r] || e.checkbox;
                            if ('string' == typeof l.attr('lay-ignore')) return l.show();
                            var d = l.next('.' + u[0]),
                                f = t(['<div class="layui-unselect ' + u[0],
                                    n.checked ? ' ' + u[1] : '',
                                    o ? ' layui-checkbox-disbaled ' + c : '',
                                    '"',
                                    r ? ' lay-skin="' + r + '"' : '',
                                    '>',
                                    function () {
                                        var e = n.title.replace(/\s/g, ''),
                                            t = {
                                                checkbox: [
                                                    e ? '<span>' + n.title + '</span>' : '',
                                                    '<i class="layui-icon layui-icon-ok"></i>'
                                                ].join(''),
                                                _switch: '<em>' + ((n.checked ? s[0] : s[1]) || '') + '</em><i></i>'
                                            };
                                        return t[r] || t.checkbox
                                    }(),
                                    '</div>'].join(''));
                            d[0] && d.remove(),
                                l.after(f),
                                a.call(this, f, u)
                        })
                    },
                    radio: function () {
                        var e = 'layui-form-radio',
                            i = [
                                '&#xe643;',
                                '&#xe63f;'
                            ],
                            a = u.find('input[type=radio]'),
                            n = function (a) {
                                var n = t(this),
                                    s = 'layui-anim-scaleSpring';
                                a.on('click', function () {
                                    var o = n[0].name,
                                        c = n.parents(r),
                                        u = n.attr('lay-filter'),
                                        d = c.find('input[name=' + o.replace(/(\.|#|\[|\])/g, '\\$1') + ']');
                                    n[0].disabled || (layui.each(d, function () {
                                        var a = t(this).next('.' + e);
                                        this.checked = !1,
                                            a.removeClass(e + 'ed'),
                                            a.find('.layui-icon').removeClass(s).html(i[1])
                                    }), n[0].checked = !0, a.addClass(e + 'ed'), a.find('.layui-icon').addClass(s).html(i[0]), layui.event.call(n[0], l, 'radio(' + u + ')', {
                                        elem: n[0],
                                        value: n[0].value,
                                        othis: a
                                    }))
                                })
                            };
                        a.each(function (a, l) {
                            var r = t(this),
                                s = r.next('.' + e),
                                o = this.disabled;
                            if ('string' == typeof r.attr('lay-ignore')) return r.show();
                            s[0] && s.remove();
                            var u = t(['<div class="layui-unselect ' + e,
                                l.checked ? ' ' + e + 'ed' : '',
                                (o ? ' layui-radio-disbaled ' + c : '') + '">',
                                '<i class="layui-anim layui-icon">' + i[l.checked ? 0 : 1] + '</i>',
                                '<div>' + function () {
                                    var e = l.title || '';
                                    return 'string' == typeof r.next().attr('lay-radio') && (e = r.next().html(), r.next().remove()),
                                        e
                                }() + '</div>',
                                '</div>'].join(''));
                            r.after(u),
                                n.call(this, u)
                        })
                    }
                };
            return e ? d[e] ? d[e]() : a.error('不支持的' + e + '表单渲染') : layui.each(d, function (e, t) {
                t()
            }),
                n
        };
    var d = function () {
            var e = null,
                a = f.config.verify,
                s = 'layui-form-danger',
                o = {},
                c = t(this),
                u = c.parents(r),
                d = u.find('*[lay-verify]'),
                v = c.parents('form') [0],
                h = c.attr('lay-filter');
            return layui.each(d, function (l, r) {
                var o = t(this),
                    c = o.attr('lay-verify').split('|'),
                    u = o.attr('lay-verType'),
                    d = o.val();
                if (o.removeClass(s), layui.each(c, function (t, l) {
                    var c,
                        f = '',
                        v = 'function' == typeof a[l];
                    if (a[l]) {
                        var c = v ? f = a[l](d, r) : !a[l][0].test(d);
                        if (f = f || a[l][1], 'required' === l && (f = o.attr('lay-reqText') || f), c) return 'tips' === u ? i.tips(f, function () {
                            return 'string' == typeof o.attr('lay-ignore') || 'select' !== r.tagName.toLowerCase() && !/^checkbox|radio$/.test(r.type) ? o : o.next()
                        }(), {
                            tips: 1
                        }) : 'alert' === u ? i.alert(f, {
                            title: '提示',
                            shadeClose: !0
                        }) : i.msg(f, {
                            icon: 5,
                            shift: 6
                        }),
                        n.android || n.ios || setTimeout(function () {
                            r.focus()
                        }, 7),
                            o.addClass(s),
                            e = !0
                    }
                }), e) return e
            }),
            !e && (o = f.getValue(null, u), layui.event.call(this, l, 'submit(' + h + ')', {
                elem: this,
                form: v,
                field: o
            }))
        },
        f = new u,
        v = t(document),
        h = t(window);
    f.render(),
        v.on('reset', r, function () {
            var e = t(this).attr('lay-filter');
            setTimeout(function () {
                f.render(null, e)
            }, 50)
        }),
        v.on('submit', r, d).on('click', '*[lay-submit]', d),
        e(l, f)
});
layui.define('form', function (e) {
    'use strict';
    var i = layui.$,
        a = layui.form,
        n = layui.layer,
        t = 'tree',
        r = {
            config: {},
            index: layui[t] ? layui[t].index + 10000 : 0,
            set: function (e) {
                var a = this;
                return a.config = i.extend({}, a.config, e),
                    a
            },
            on: function (e, i) {
                return layui.onevent.call(this, t, e, i)
            }
        },
        l = function () {
            var e = this,
                i = e.config,
                a = i.id || e.index;
            return l.that[a] = e,
                l.config[a] = i,
                {
                    config: i,
                    reload: function (i) {
                        e.reload.call(e, i)
                    },
                    getChecked: function () {
                        return e.getChecked.call(e)
                    },
                    setChecked: function (i) {
                        return e.setChecked.call(e, i)
                    }
                }
        },
        c = 'layui-hide',
        d = 'layui-disabled',
        s = 'layui-tree-set',
        o = 'layui-tree-iconClick',
        h = 'layui-icon-addition',
        u = 'layui-icon-subtraction',
        p = 'layui-tree-entry',
        f = 'layui-tree-main',
        y = 'layui-tree-txt',
        v = 'layui-tree-pack',
        C = 'layui-tree-spread',
        k = 'layui-tree-setLineShort',
        m = 'layui-tree-showLine',
        x = 'layui-tree-lineExtend',
        b = function (e) {
            var a = this;
            a.index = ++r.index,
                a.config = i.extend({}, a.config, r.config, e),
                a.render()
        };
    b.prototype.config = {
        data: [],
        showCheckbox: !1,
        showLine: !0,
        accordion: !1,
        onlyIconControl: !1,
        isJump: !1,
        edit: !1,
        text: {
            defaultNodeName: '未命名',
            none: '无数据'
        }
    },
        b.prototype.reload = function (e) {
            var a = this;
            layui.each(e, function (e, i) {
                i.constructor === Array && delete a.config[e]
            }),
                a.config = i.extend(!0, {}, a.config, e),
                a.render()
        },
        b.prototype.render = function () {
            var e = this,
                a = e.config;
            e.checkids = [];
            var n = i('<div class="layui-tree' + (a.showCheckbox ? ' layui-form' : '') + (a.showLine ? ' layui-tree-line' : '') + '" lay-filter="LAY-tree-' + e.index + '"></div>');
            e.tree(n);
            var t = a.elem = i(a.elem);
            if (t[0]) {
                if (e.key = a.id || e.index, e.elem = n, e.elemNone = i('<div class="layui-tree-emptyText">' + a.text.none + '</div>'), t.html(e.elem), 0 == e.elem.find('.layui-tree-set').length) return e.elem.append(e.elemNone);
                a.showCheckbox && e.renderForm('checkbox'),
                    e.elem.find('.layui-tree-set').each(function () {
                        var e = i(this);
                        e.parent('.layui-tree-pack') [0] || e.addClass('layui-tree-setHide'),
                        !e.next() [0] && e.parents('.layui-tree-pack').eq(1).hasClass('layui-tree-lineExtend') && e.addClass(k),
                        e.next() [0] || e.parents('.layui-tree-set').eq(0).next() [0] || e.addClass(k)
                    }),
                    e.events()
            }
        },
        b.prototype.renderForm = function (e) {
            a.render(e, 'LAY-tree-' + this.index)
        },
        b.prototype.tree = function (e, a) {
            var n = this,
                t = n.config,
                r = a || t.data;
            layui.each(r, function (a, r) {
                var l = r.children && r.children.length > 0,
                    o = i('<div class="layui-tree-pack" ' + (r.spread ? 'style="display: block;"' : '') + '"></div>'),
                    h = i(['<div data-id="' + r.id + '" class="layui-tree-set' + (r.spread ? ' layui-tree-spread' : '') + (r.checked ? ' layui-tree-checkedFirst' : '') + '">',
                        '<div class="layui-tree-entry">',
                        '<div class="layui-tree-main">',
                        function () {
                            return t.showLine ? l ? '<span class="layui-tree-iconClick layui-tree-icon"><i class="layui-icon ' + (r.spread ? 'layui-icon-subtraction' : 'layui-icon-addition') + '"></i></span>' : '<span class="layui-tree-iconClick"><i class="layui-icon layui-icon-file"></i></span>' : '<span class="layui-tree-iconClick"><i class="layui-tree-iconArrow ' + (l ? '' : c) + '"></i></span>'
                        }(),
                        function () {
                            return t.showCheckbox ? '<input type="checkbox" name="' + (r.field || 'layuiTreeCheck_' + r.id) + '" same="layuiTreeCheck" lay-skin="primary" ' + (r.disabled ? 'disabled' : '') + ' value="' + r.id + '">' : ''
                        }(),
                        function () {
                            return t.isJump && r.href ? '<a href="' + r.href + '" target="_blank" class="' + y + '">' + (r.title || r.label || t.text.defaultNodeName) + '</a>' : '<span class="' + y + (r.disabled ? ' ' + d : '') + '">' + (r.title || r.label || t.text.defaultNodeName) + '</span>'
                        }(),
                        '</div>',
                        function () {
                            if (!t.edit) return '';
                            var e = {
                                    add: '<i class="layui-icon layui-icon-add-1"  data-type="add"></i>',
                                    update: '<i class="layui-icon layui-icon-edit" data-type="update"></i>',
                                    del: '<i class="layui-icon layui-icon-delete" data-type="del"></i>'
                                },
                                i = [
                                    '<div class="layui-btn-group layui-tree-btnGroup">'
                                ];
                            return t.edit === !0 && (t.edit = [
                                'update',
                                'del'
                            ]),
                                'object' == typeof t.edit ? (layui.each(t.edit, function (a, n) {
                                    i.push(e[n] || '')
                                }), i.join('') + '</div>') : void 0
                        }(),
                        '</div></div>'].join(''));
                l && (h.append(o), n.tree(o, r.children)),
                    e.append(h),
                h.prev('.' + s) [0] && h.prev().children('.layui-tree-pack').addClass('layui-tree-showLine'),
                l || h.parent('.layui-tree-pack').addClass('layui-tree-lineExtend'),
                    n.spread(h, r),
                t.showCheckbox && (r.checked && n.checkids.push(r.id), n.checkClick(h, r)),
                t.edit && n.operate(h, r)
            })
        },
        b.prototype.spread = function (e, a) {
            var n = this,
                t = n.config,
                r = e.children('.' + p),
                l = r.children('.' + f),
                c = r.find('.' + o),
                k = r.find('.' + y),
                m = t.onlyIconControl ? c : l,
                x = '';
            m.on('click', function (i) {
                var a = e.children('.' + v),
                    n = m.children('.layui-icon') [0] ? m.children('.layui-icon') : m.find('.layui-tree-icon').children('.layui-icon');
                if (a[0]) {
                    if (e.hasClass(C)) e.removeClass(C),
                        a.slideUp(200),
                        n.removeClass(u).addClass(h);
                    else if (e.addClass(C), a.slideDown(200), n.addClass(u).removeClass(h), t.accordion) {
                        var r = e.siblings('.' + s);
                        r.removeClass(C),
                            r.children('.' + v).slideUp(200),
                            r.find('.layui-tree-icon').children('.layui-icon').removeClass(u).addClass(h)
                    }
                } else x = 'normal'
            }),
                k.on('click', function () {
                    var n = i(this);
                    n.hasClass(d) || (x = e.hasClass(C) ? t.onlyIconControl ? 'open' : 'close' : t.onlyIconControl ? 'close' : 'open', t.click && t.click({
                        elem: e,
                        state: x,
                        data: a
                    }))
                })
        },
        b.prototype.setCheckbox = function (e, i, a) {
            var n = this,
                t = (n.config, a.prop('checked'));
            if (!a.prop('disabled')) {
                if ('object' == typeof i.children || e.find('.' + v) [0]) {
                    var r = e.find('.' + v).find('input[same="layuiTreeCheck"]');
                    r.each(function () {
                        this.disabled || (this.checked = t)
                    })
                }
                var l = function (e) {
                    if (e.parents('.' + s) [0]) {
                        var i,
                            a = e.parent('.' + v),
                            n = a.parent(),
                            r = a.prev().find('input[same="layuiTreeCheck"]');
                        t ? r.prop('checked', t) : (a.find('input[same="layuiTreeCheck"]').each(function () {
                            this.checked && (i = !0)
                        }), i || r.prop('checked', !1)),
                            l(n)
                    }
                };
                l(e),
                    n.renderForm('checkbox')
            }
        },
        b.prototype.checkClick = function (e, a) {
            var n = this,
                t = n.config,
                r = e.children('.' + p),
                l = r.children('.' + f);
            l.on('click', 'input[same="layuiTreeCheck"]+', function (r) {
                layui.stope(r);
                var l = i(this).prev(),
                    c = l.prop('checked');
                l.prop('disabled') || (n.setCheckbox(e, a, l), t.oncheck && t.oncheck({
                    elem: e,
                    checked: c,
                    data: a
                }))
            })
        },
        b.prototype.operate = function (e, a) {
            var t = this,
                r = t.config,
                l = e.children('.' + p),
                d = l.children('.' + f);
            l.children('.layui-tree-btnGroup').on('click', '.layui-icon', function (l) {
                layui.stope(l);
                var f = i(this).data('type'),
                    b = e.children('.' + v),
                    g = {
                        data: a,
                        type: f,
                        elem: e
                    };
                if ('add' == f) {
                    b[0] || (r.showLine ? (d.find('.' + o).addClass('layui-tree-icon'), d.find('.' + o).children('.layui-icon').addClass(h).removeClass('layui-icon-file')) : d.find('.layui-tree-iconArrow').removeClass(c), e.append('<div class="layui-tree-pack"></div>'));
                    var w = r.operate && r.operate(g),
                        N = {};
                    if (N.title = r.text.defaultNodeName, N.id = w, t.tree(e.children('.' + v), [
                        N
                    ]), r.showLine) if (b[0]) b.hasClass(x) || b.addClass(x),
                        e.find('.' + v).each(function () {
                            i(this).children('.' + s).last().addClass(k)
                        }),
                        b.children('.' + s).last().prev().hasClass(k) ? b.children('.' + s).last().prev().removeClass(k) : b.children('.' + s).last().removeClass(k),
                    !e.parent('.' + v) [0] && e.next() [0] && b.children('.' + s).last().removeClass(k);
                    else {
                        var T = e.siblings('.' + s),
                            L = 1,
                            A = e.parent('.' + v);
                        layui.each(T, function (e, a) {
                            i(a).children('.' + v) [0] || (L = 0)
                        }),
                            1 == L ? (T.children('.' + v).addClass(m), T.children('.' + v).children('.' + s).removeClass(k), e.children('.' + v).addClass(m), A.removeClass(x), A.children('.' + s).last().children('.' + v).children('.' + s).last().addClass(k)) : e.children('.' + v).children('.' + s).addClass(k)
                    }
                    if (!r.showCheckbox) return;
                    if (d.find('input[same="layuiTreeCheck"]') [0].checked) {
                        var I = e.children('.' + v).children('.' + s).last();
                        I.find('input[same="layuiTreeCheck"]') [0].checked = !0
                    }
                    t.renderForm('checkbox')
                } else if ('update' == f) {
                    var F = d.children('.' + y).html();
                    d.children('.' + y).html(''),
                        d.append('<input type="text" class="layui-tree-editInput">'),
                        d.children('.layui-tree-editInput').val(F).focus();
                    var j = function (e) {
                        var i = e.val().trim();
                        i = i ? i : r.text.defaultNodeName,
                            e.remove(),
                            d.children('.' + y).html(i),
                            g.data.title = i,
                        r.operate && r.operate(g)
                    };
                    d.children('.layui-tree-editInput').blur(function () {
                        j(i(this))
                    }),
                        d.children('.layui-tree-editInput').on('keydown', function (e) {
                            13 === e.keyCode && (e.preventDefault(), j(i(this)))
                        })
                } else n.confirm('确认删除该节点 "<span style="color: #999;">' + (a.title || '') + '</span>" 吗？', function (a) {
                    if (r.operate && r.operate(g), g.status = 'remove', n.close(a), !e.prev('.' + s) [0] && !e.next('.' + s) [0] && !e.parent('.' + v) [0]) return e.remove(),
                        void t.elem.append(t.elemNone);
                    if (e.siblings('.' + s).children('.' + p) [0]) {
                        if (r.showCheckbox) {
                            var l = function (e) {
                                if (e.parents('.' + s) [0]) {
                                    var a = e.siblings('.' + s).children('.' + p),
                                        n = e.parent('.' + v).prev(),
                                        r = n.find('input[same="layuiTreeCheck"]') [0],
                                        c = 1,
                                        d = 0;
                                    0 == r.checked && (a.each(function (e, a) {
                                        var n = i(a).find('input[same="layuiTreeCheck"]') [0];
                                        0 != n.checked || n.disabled || (c = 0),
                                        n.disabled || (d = 1)
                                    }), 1 == c && 1 == d && (r.checked = !0, t.renderForm('checkbox'), l(n.parent('.' + s))))
                                }
                            };
                            l(e)
                        }
                        if (r.showLine) {
                            var d = e.siblings('.' + s),
                                h = 1,
                                f = e.parent('.' + v);
                            layui.each(d, function (e, a) {
                                i(a).children('.' + v) [0] || (h = 0)
                            }),
                                1 == h ? (b[0] || (f.removeClass(x), d.children('.' + v).addClass(m), d.children('.' + v).children('.' + s).removeClass(k)), e.next() [0] ? f.children('.' + s).last().children('.' + v).children('.' + s).last().addClass(k) : e.prev().children('.' + v).children('.' + s).last().addClass(k), e.next() [0] || e.parents('.' + s) [1] || e.parents('.' + s).eq(0).next() [0] || e.prev('.' + s).addClass(k)) : !e.next() [0] && e.hasClass(k) && e.prev().addClass(k)
                        }
                    } else {
                        var y = e.parent('.' + v).prev();
                        if (r.showLine) {
                            y.find('.' + o).removeClass('layui-tree-icon'),
                                y.find('.' + o).children('.layui-icon').removeClass(u).addClass('layui-icon-file');
                            var w = y.parents('.' + v).eq(0);
                            w.addClass(x),
                                w.children('.' + s).each(function () {
                                    i(this).children('.' + v).children('.' + s).last().addClass(k)
                                })
                        } else y.find('.layui-tree-iconArrow').addClass(c);
                        e.parents('.' + s).eq(0).removeClass(C),
                            e.parent('.' + v).remove()
                    }
                    e.remove()
                })
            })
        },
        b.prototype.events = function () {
            var e = this,
                a = e.config;
            e.elem.find('.layui-tree-checkedFirst');
            e.setChecked(e.checkids),
                e.elem.find('.layui-tree-search').on('keyup', function () {
                    var n = i(this),
                        t = n.val(),
                        r = n.nextAll(),
                        l = [];
                    r.find('.' + y).each(function () {
                        var e = i(this).parents('.' + p);
                        if (i(this).html().indexOf(t) != -1) {
                            l.push(i(this).parent());
                            var a = function (e) {
                                e.addClass('layui-tree-searchShow'),
                                e.parent('.' + v) [0] && a(e.parent('.' + v).parent('.' + s))
                            };
                            a(e.parent('.' + s))
                        }
                    }),
                        r.find('.' + p).each(function () {
                            var e = i(this).parent('.' + s);
                            e.hasClass('layui-tree-searchShow') || e.addClass(c)
                        }),
                    0 == r.find('.layui-tree-searchShow').length && e.elem.append(e.elemNone),
                    a.onsearch && a.onsearch({
                        elem: l
                    })
                }),
                e.elem.find('.layui-tree-search').on('keydown', function () {
                    i(this).nextAll().find('.' + p).each(function () {
                        var e = i(this).parent('.' + s);
                        e.removeClass('layui-tree-searchShow ' + c)
                    }),
                    i('.layui-tree-emptyText') [0] && i('.layui-tree-emptyText').remove()
                })
        },
        b.prototype.getChecked = function () {
            var e = this,
                a = e.config,
                n = [],
                t = [];
            e.elem.find('.layui-form-checked').each(function () {
                n.push(i(this).prev() [0].value)
            });
            var r = function (e, a) {
                layui.each(e, function (e, t) {
                    layui.each(n, function (e, n) {
                        if (t.id == n) {
                            var l = i.extend({}, t);
                            return delete l.children,
                                a.push(l),
                            t.children && (l.children = [], r(t.children, l.children)),
                                !0
                        }
                    })
                })
            };
            return r(i.extend({}, a.data), t),
                t
        },
        b.prototype.setChecked = function (e) {
            var a = this;
            a.config;
            a.elem.find('.' + s).each(function (a, n) {
                var t = i(this).data('id'),
                    r = i(n).children('.' + p).find('input[same="layuiTreeCheck"]'),
                    l = r.next();
                if ('number' == typeof e) {
                    if (t == e) return r[0].checked || l.click(),
                        !1
                } else 'object' == typeof e && layui.each(e, function (e, i) {
                    if (i == t && !r[0].checked) return l.click(),
                        !0
                })
            })
        },
        l.that = {},
        l.config = {},
        r.reload = function (e, i) {
            var a = l.that[e];
            return a.reload(i),
                l.call(a)
        },
        r.getChecked = function (e) {
            var i = l.that[e];
            return i.getChecked()
        },
        r.setChecked = function (e, i) {
            var a = l.that[e];
            return a.setChecked(i)
        },
        r.render = function (e) {
            var i = new b(e);
            return l.call(i)
        },
        e(t, r)
});
layui.define(['laytpl',
    'form'], function (e) {
    'use strict';
    var a = layui.$,
        t = layui.laytpl,
        n = layui.form,
        i = 'transfer',
        l = {
            config: {},
            index: layui[i] ? layui[i].index + 10000 : 0,
            set: function (e) {
                var t = this;
                return t.config = a.extend({}, t.config, e),
                    t
            },
            on: function (e, a) {
                return layui.onevent.call(this, i, e, a)
            }
        },
        r = function () {
            var e = this,
                a = e.config,
                t = a.id || e.index;
            return r.that[t] = e,
                r.config[t] = a,
                {
                    config: a,
                    reload: function (a) {
                        e.reload.call(e, a)
                    },
                    getData: function () {
                        return e.getData.call(e)
                    }
                }
        },
        c = 'layui-hide',
        o = 'layui-btn-disabled',
        d = 'layui-none',
        s = 'layui-transfer-box',
        u = 'layui-transfer-header',
        h = 'layui-transfer-search',
        f = 'layui-transfer-active',
        y = 'layui-transfer-data',
        p = function (e) {
            return e = e || {},
                [
                    '<div class="layui-transfer-box" data-index="' + e.index + '">',
                    '<div class="layui-transfer-header">',
                    '<input type="checkbox" name="' + e.checkAllName + '" lay-filter="layTransferCheckbox" lay-type="all" lay-skin="primary" title="{{ d.data.title[' + e.index + '] || \'list' + (e.index + 1) + '\' }}">',
                    '</div>',
                    '{{# if(d.data.showSearch){ }}',
                    '<div class="layui-transfer-search">',
                    '<i class="layui-icon layui-icon-search"></i>',
                    '<input type="input" class="layui-input" placeholder="关键词搜索">',
                    '</div>',
                    '{{# } }}',
                    '<ul class="layui-transfer-data"></ul>',
                    '</div>'
                ].join('')
        },
        v = [
            '<div class="layui-transfer layui-form layui-border-box" lay-filter="LAY-transfer-{{ d.index }}">',
            p({
                index: 0,
                checkAllName: 'layTransferLeftCheckAll'
            }),
            '<div class="layui-transfer-active">',
            '<button type="button" class="layui-btn layui-btn-sm layui-btn-primary layui-btn-disabled" data-index="0">',
            '<i class="layui-icon layui-icon-next"></i>',
            '</button>',
            '<button type="button" class="layui-btn layui-btn-sm layui-btn-primary layui-btn-disabled" data-index="1">',
            '<i class="layui-icon layui-icon-prev"></i>',
            '</button>',
            '</div>',
            p({
                index: 1,
                checkAllName: 'layTransferRightCheckAll'
            }),
            '</div>'
        ].join(''),
        x = function (e) {
            var t = this;
            t.index = ++l.index,
                t.config = a.extend({}, t.config, l.config, e),
                t.render()
        };
    x.prototype.config = {
        title: [
            '列表一',
            '列表二'
        ],
        width: 200,
        height: 360,
        data: [],
        value: [],
        showSearch: !1,
        id: '',
        text: {
            none: '无数据',
            searchNone: '无匹配数据'
        }
    },
        x.prototype.reload = function (e) {
            var t = this;
            layui.each(e, function (e, a) {
                a.constructor === Array && delete t.config[e]
            }),
                t.config = a.extend(!0, {}, t.config, e),
                t.render()
        },
        x.prototype.render = function () {
            var e = this,
                n = e.config,
                i = e.elem = a(t(v).render({
                    data: n,
                    index: e.index
                })),
                l = n.elem = a(n.elem);
            l[0] && (n.data = n.data || [], n.value = n.value || [], e.key = n.id || e.index, l.html(e.elem), e.layBox = e.elem.find('.' + s), e.layHeader = e.elem.find('.' + u), e.laySearch = e.elem.find('.' + h), e.layData = i.find('.' + y), e.layBtn = i.find('.' + f + ' .layui-btn'), e.layBox.css({
                width: n.width,
                height: n.height
            }), e.layData.css({
                height: function () {
                    return n.height - e.layHeader.outerHeight() - e.laySearch.outerHeight() - 2
                }()
            }), e.renderData(), e.events())
        },
        x.prototype.renderData = function () {
            var e = this,
                a = (e.config, [
                    {
                        checkName: 'layTransferLeftCheck',
                        views: []
                    },
                    {
                        checkName: 'layTransferRightCheck',
                        views: []
                    }
                ]);
            e.parseData(function (e) {
                var t = e.selected ? 1 : 0,
                    n = [
                        '<li>',
                        '<input type="checkbox" name="' + a[t].checkName + '" lay-skin="primary" lay-filter="layTransferCheckbox" title="' + e.title + '"' + (e.disabled ? ' disabled' : '') + (e.checked ? ' checked' : '') + ' value="' + e.value + '">',
                        '</li>'
                    ].join('');
                a[t].views.push(n),
                    delete e.selected
            }),
                e.layData.eq(0).html(a[0].views.join('')),
                e.layData.eq(1).html(a[1].views.join('')),
                e.renderCheckBtn()
        },
        x.prototype.renderForm = function (e) {
            n.render(e, 'LAY-transfer-' + this.index)
        },
        x.prototype.renderCheckBtn = function (e) {
            var t = this,
                n = t.config;
            e = e || {},
                t.layBox.each(function (i) {
                    var l = a(this),
                        r = l.find('.' + y),
                        d = l.find('.' + u).find('input[type="checkbox"]'),
                        s = r.find('input[type="checkbox"]'),
                        h = 0,
                        f = !1;
                    if (s.each(function () {
                        var e = a(this).data('hide');
                        (this.checked || this.disabled || e) && h++,
                        this.checked && !e && (f = !0)
                    }), d.prop('checked', f && h === s.length), t.layBtn.eq(i) [f ? 'removeClass' : 'addClass'](o), !e.stopNone) {
                        var p = r.children('li:not(.' + c + ')').length;
                        t.noneView(r, p ? '' : n.text.none)
                    }
                }),
                t.renderForm('checkbox')
        },
        x.prototype.noneView = function (e, t) {
            var n = a('<p class="layui-none">' + (t || '') + '</p>');
            e.find('.' + d) [0] && e.find('.' + d).remove(),
            t.replace(/\s/g, '') && e.append(n)
        },
        x.prototype.setValue = function () {
            var e = this,
                t = e.config,
                n = [];
            return e.layBox.eq(1).find('.' + y + ' input[type="checkbox"]').each(function () {
                var e = a(this).data('hide');
                e || n.push(this.value)
            }),
                t.value = n,
                e
        },
        x.prototype.parseData = function (e) {
            var t = this,
                n = t.config,
                i = [];
            return layui.each(n.data, function (t, l) {
                l = ('function' == typeof n.parseData ? n.parseData(l) : l) || l,
                    i.push(l = a.extend({}, l)),
                    layui.each(n.value, function (e, a) {
                        a == l.value && (l.selected = !0)
                    }),
                e && e(l)
            }),
                n.data = i,
                t
        },
        x.prototype.getData = function (e) {
            var a = this,
                t = a.config,
                n = [];
            return a.setValue(),
                layui.each(e || t.value, function (e, a) {
                    layui.each(t.data, function (e, t) {
                        delete t.selected,
                        a == t.value && n.push(t)
                    })
                }),
                n
        },
        x.prototype.events = function () {
            var e = this,
                t = e.config;
            e.elem.on('click', 'input[lay-filter="layTransferCheckbox"]+', function () {
                var t = a(this).prev(),
                    n = t[0].checked,
                    i = t.parents('.' + s).eq(0).find('.' + y);
                t[0].disabled || ('all' === t.attr('lay-type') && i.find('input[type="checkbox"]').each(function () {
                    this.disabled || (this.checked = n)
                }), e.renderCheckBtn({
                    stopNone: !0
                }))
            }),
                e.layBtn.on('click', function () {
                    var n = a(this),
                        i = n.data('index'),
                        l = e.layBox.eq(i),
                        r = [];
                    if (!n.hasClass(o)) {
                        e.layBox.eq(i).each(function (t) {
                            var n = a(this),
                                i = n.find('.' + y);
                            i.children('li').each(function () {
                                var t = a(this),
                                    n = t.find('input[type="checkbox"]'),
                                    i = n.data('hide');
                                n[0].checked && !i && (n[0].checked = !1, l.siblings('.' + s).find('.' + y).append(t.clone()), t.remove(), r.push(n[0].value)),
                                    e.setValue()
                            })
                        }),
                            e.renderCheckBtn();
                        var c = l.siblings('.' + s).find('.' + h + ' input');
                        '' === c.val() || c.trigger('keyup'),
                        t.onchange && t.onchange(e.getData(r), i)
                    }
                }),
                e.laySearch.find('input').on('keyup', function () {
                    var n = this.value,
                        i = a(this).parents('.' + h).eq(0).siblings('.' + y),
                        l = i.children('li');
                    l.each(function () {
                        var e = a(this),
                            t = e.find('input[type="checkbox"]'),
                            i = t[0].title.indexOf(n) !== -1;
                        e[i ? 'removeClass' : 'addClass'](c),
                            t.data('hide', !i)
                    }),
                        e.renderCheckBtn();
                    var r = l.length === i.children('li.' + c).length;
                    e.noneView(i, r ? t.text.searchNone : '')
                })
        },
        r.that = {},
        r.config = {},
        l.reload = function (e, a) {
            var t = r.that[e];
            return t.reload(a),
                r.call(t)
        },
        l.getData = function (e) {
            var a = r.that[e];
            return a.getData()
        },
        l.render = function (e) {
            var a = new x(e);
            return r.call(a)
        },
        e(i, l)
});
layui.define(['laytpl',
    'laypage',
    'layer',
    'form',
    'util'], function (e) {
    'use strict';
    var t = layui.$,
        i = layui.laytpl,
        a = layui.laypage,
        l = layui.layer,
        n = layui.form,
        o = (layui.util, layui.hint()),
        r = layui.device(),
        d = {
            config: {
                checkName: 'LAY_CHECKED',
                indexName: 'LAY_TABLE_INDEX'
            },
            cache: {},
            index: layui.table ? layui.table.index + 10000 : 0,
            set: function (e) {
                var i = this;
                return i.config = t.extend({}, i.config, e),
                    i
            },
            on: function (e, t) {
                return layui.onevent.call(this, y, e, t)
            }
        },
        c = function () {
            var e = this,
                t = e.config,
                i = t.id || t.index;
            return i && (c.that[i] = e, c.config[i] = t),
                {
                    config: t,
                    reload: function (t) {
                        e.reload.call(e, t)
                    },
                    setColsWidth: function () {
                        e.setColsWidth.call(e)
                    },
                    resize: function () {
                        e.resize.call(e)
                    }
                }
        },
        s = function (e) {
            var t = c.config[e];
            return t || o.error('The ID option was not found in the table instance'),
            t || null
        },
        u = function (e, a, l, n) {
            var o = e.templet ? function () {
                return 'function' == typeof e.templet ? e.templet(l) : i(t(e.templet).html() || String(a)).render(l)
            }() : a;
            return n ? t('<div>' + o + '</div>').text() : o
        },
        y = 'table',
        h = '.layui-table',
        f = 'layui-hide',
        p = 'layui-none',
        v = 'layui-table-view',
        m = '.layui-table-tool',
        g = '.layui-table-box',
        b = '.layui-table-init',
        x = '.layui-table-header',
        k = '.layui-table-body',
        C = '.layui-table-main',
        w = '.layui-table-fixed',
        T = '.layui-table-fixed-l',
        A = '.layui-table-fixed-r',
        L = '.layui-table-total',
        N = '.layui-table-page',
        S = '.layui-table-sort',
        W = 'layui-table-edit',
        _ = 'layui-table-hover',
        E = function (e) {
            var t = '{{#if(item2.colspan){}} colspan="{{item2.colspan}}"{{#} if(item2.rowspan){}} rowspan="{{item2.rowspan}}"{{#}}}';
            return e = e || {},
                [
                    '<table cellspacing="0" cellpadding="0" border="0" class="layui-table" ',
                    '{{# if(d.data.skin){ }}lay-skin="{{d.data.skin}}"{{# } }} {{# if(d.data.size){ }}lay-size="{{d.data.size}}"{{# } }} {{# if(d.data.even){ }}lay-even{{# } }}>',
                    '<thead>',
                    '{{# layui.each(d.data.cols, function(i1, item1){ }}',
                    '<tr>',
                    '{{# layui.each(item1, function(i2, item2){ }}',
                    '{{# if(item2.fixed && item2.fixed !== "right"){ left = true; } }}',
                    '{{# if(item2.fixed === "right"){ right = true; } }}',
                    function () {
                        return e.fixed && 'right' !== e.fixed ? '{{# if(item2.fixed && item2.fixed !== "right"){ }}' : 'right' === e.fixed ? '{{# if(item2.fixed === "right"){ }}' : ''
                    }(),
                    '{{# var isSort = !(item2.colGroup) && item2.sort; }}',
                    '<th data-field="{{ item2.field||i2 }}" data-key="{{d.index}}-{{i1}}-{{i2}}" {{# if( item2.parentKey){ }}data-parentkey="{{ item2.parentKey }}"{{# } }} {{# if(item2.minWidth){ }}data-minwidth="{{item2.minWidth}}"{{# } }} ' + t + ' {{# if(item2.unresize || item2.colGroup){ }}data-unresize="true"{{# } }} class="{{# if(item2.hide){ }}layui-hide{{# } }}{{# if(isSort){ }} layui-unselect{{# } }}{{# if(!item2.field){ }} layui-table-col-special{{# } }}">',
                    '<div class="layui-table-cell laytable-cell-',
                    '{{# if(item2.colGroup){ }}',
                    'group',
                    '{{# } else { }}',
                    '{{d.index}}-{{i1}}-{{i2}}',
                    '{{# if(item2.type !== "normal"){ }}',
                    ' laytable-cell-{{ item2.type }}',
                    '{{# } }}',
                    '{{# } }}',
                    '" {{#if(item2.align){}}align="{{item2.align}}"{{#}}}>',
                    '{{# if(item2.type === "checkbox"){ }}',
                    '<input type="checkbox" name="layTableCheckbox" lay-skin="primary" lay-filter="layTableAllChoose" {{# if(item2[d.data.checkName]){ }}checked{{# }; }}>',
                    '{{# } else { }}',
                    '<span>{{item2.title||""}}</span>',
                    '{{# if(isSort){ }}',
                    '<span class="layui-table-sort layui-inline"><i class="layui-edge layui-table-sort-asc" title="升序"></i><i class="layui-edge layui-table-sort-desc" title="降序"></i></span>',
                    '{{# } }}',
                    '{{# } }}',
                    '</div>',
                    '</th>',
                    e.fixed ? '{{# }; }}' : '',
                    '{{# }); }}',
                    '</tr>',
                    '{{# }); }}',
                    '</thead>',
                    '</table>'
                ].join('')
        },
        z = [
            '<table cellspacing="0" cellpadding="0" border="0" class="layui-table" ',
            '{{# if(d.data.skin){ }}lay-skin="{{d.data.skin}}"{{# } }} {{# if(d.data.size){ }}lay-size="{{d.data.size}}"{{# } }} {{# if(d.data.even){ }}lay-even{{# } }}>',
            '<tbody></tbody>',
            '</table>'
        ].join(''),
        H = [
            '<div class="layui-form layui-border-box {{d.VIEW_CLASS}}" lay-filter="LAY-table-{{d.index}}" lay-id="{{ d.data.id }}" style="{{# if(d.data.width){ }}width:{{d.data.width}}px;{{# } }} {{# if(d.data.height){ }}height:{{d.data.height}}px;{{# } }}">',
            '{{# if(d.data.toolbar){ }}',
            '<div class="layui-table-tool">',
            '<div class="layui-table-tool-temp"></div>',
            '<div class="layui-table-tool-self"></div>',
            '</div>',
            '{{# } }}',
            '<div class="layui-table-box">',
            '{{# if(d.data.loading){ }}',
            '<div class="layui-table-init" style="background-color: #fff;">',
            '<i class="layui-icon layui-icon-loading layui-anim layui-anim-rotate layui-anim-loop"></i>',
            '</div>',
            '{{# } }}',
            '{{# var left, right; }}',
            '<div class="layui-table-header">',
            E(),
            '</div>',
            '<div class="layui-table-body layui-table-main">',
            z,
            '</div>',
            '{{# if(left){ }}',
            '<div class="layui-table-fixed layui-table-fixed-l">',
            '<div class="layui-table-header">',
            E({
                fixed: !0
            }),
            '</div>',
            '<div class="layui-table-body">',
            z,
            '</div>',
            '</div>',
            '{{# }; }}',
            '{{# if(right){ }}',
            '<div class="layui-table-fixed layui-table-fixed-r">',
            '<div class="layui-table-header">',
            E({
                fixed: 'right'
            }),
            '<div class="layui-table-mend"></div>',
            '</div>',
            '<div class="layui-table-body">',
            z,
            '</div>',
            '</div>',
            '{{# }; }}',
            '</div>',
            '{{# if(d.data.totalRow){ }}',
            '<div class="layui-table-total">',
            '<table cellspacing="0" cellpadding="0" border="0" class="layui-table" ',
            '{{# if(d.data.skin){ }}lay-skin="{{d.data.skin}}"{{# } }} {{# if(d.data.size){ }}lay-size="{{d.data.size}}"{{# } }} {{# if(d.data.even){ }}lay-even{{# } }}>',
            '<tbody><tr><td><div class="layui-table-cell" style="visibility: hidden;">Total</div></td></tr></tbody>',
            '</table>',
            '</div>',
            '{{# } }}',
            '{{# if(d.data.page){ }}',
            '<div class="layui-table-page">',
            '<div id="layui-table-page{{d.index}}"></div>',
            '</div>',
            '{{# } }}',
            '<style>',
            '{{# layui.each(d.data.cols, function(i1, item1){',
            'layui.each(item1, function(i2, item2){ }}',
            '.laytable-cell-{{d.index}}-{{i1}}-{{i2}}{ ',
            '{{# if(item2.width){ }}',
            'width: {{item2.width}}px;',
            '{{# } }}',
            ' }',
            '{{# });',
            '}); }}',
            '</style>',
            '</div>'
        ].join(''),
        R = t(window),
        F = t(document),
        j = function (e) {
            var i = this;
            i.index = ++d.index,
                i.config = t.extend({}, i.config, d.config, e),
                i.render()
        };
    j.prototype.config = {
        limit: 10,
        loading: !0,
        cellMinWidth: 60,
        defaultToolbar: [
            'filter',
            'exports',
            'print'
        ],
        autoSort: !0,
        text: {
            none: '无数据'
        }
    },
        j.prototype.render = function () {
            var e = this,
                a = e.config;
            if (a.elem = t(a.elem), a.where = a.where || {}, a.id = a.id || a.elem.attr('id') || e.index, a.request = t.extend({
                pageName: 'page',
                limitName: 'limit'
            }, a.request), a.response = t.extend({
                statusName: 'code',
                statusCode: 0,
                msgName: 'msg',
                dataName: 'data',
                countName: 'count'
            }, a.response), 'object' == typeof a.page && (a.limit = a.page.limit || a.limit, a.limits = a.page.limits || a.limits, e.page = a.page.curr = a.page.curr || 1, delete a.page.elem, delete a.page.jump), !a.elem[0]) return e;
            a.height && /^full-\d+$/.test(a.height) && (e.fullHeightGap = a.height.split('-') [1], a.height = R.height() - e.fullHeightGap),
                e.setInit();
            var l = a.elem,
                n = l.next('.' + v),
                o = e.elem = t(i(H).render({
                    VIEW_CLASS: v,
                    data: a,
                    index: e.index
                }));
            if (a.index = e.index, e.key = a.id || a.index, n[0] && n.remove(), l.after(o), e.layTool = o.find(m), e.layBox = o.find(g), e.layHeader = o.find(x), e.layMain = o.find(C), e.layBody = o.find(k), e.layFixed = o.find(w), e.layFixLeft = o.find(T), e.layFixRight = o.find(A), e.layTotal = o.find(L), e.layPage = o.find(N), e.renderToolbar(), e.fullSize(), a.cols.length > 1) {
                var r = e.layFixed.find(x).find('th');
                r.height(e.layHeader.height() - 1 - parseFloat(r.css('padding-top')) - parseFloat(r.css('padding-bottom')))
            }
            e.pullData(e.page),
                e.events()
        },
        j.prototype.initOpts = function (e) {
            var t = this,
                i = (t.config, {
                    checkbox: 48,
                    radio: 48,
                    space: 15,
                    numbers: 40
                });
            e.checkbox && (e.type = 'checkbox'),
            e.space && (e.type = 'space'),
            e.type || (e.type = 'normal'),
            'normal' !== e.type && (e.unresize = !0, e.width = e.width || i[e.type])
        },
        j.prototype.setInit = function (e) {
            var t = this,
                i = t.config;
            return i.clientWidth = i.width || function () {
                var e = function (t) {
                    var a,
                        l;
                    t = t || i.elem.parent(),
                        a = t.width();
                    try {
                        l = 'none' === t.css('display')
                    } catch (n) {
                    }
                    return !t[0] || a && !l ? a : e(t.parent())
                };
                return e()
            }(),
                'width' === e ? i.clientWidth : void layui.each(i.cols, function (e, a) {
                    layui.each(a, function (l, n) {
                        if (!n) return void a.splice(l, 1);
                        if (n.key = e + '-' + l, n.hide = n.hide || !1, n.colGroup || n.colspan > 1) {
                            var o = 0;
                            layui.each(i.cols[e + 1], function (t, i) {
                                i.HAS_PARENT || o > 1 && o == n.colspan || (i.HAS_PARENT = !0, i.parentKey = e + '-' + l, o += parseInt(i.colspan > 1 ? i.colspan : 1))
                            }),
                                n.colGroup = !0
                        }
                        t.initOpts(n)
                    })
                })
        },
        j.prototype.renderToolbar = function () {
            var e = this,
                a = e.config,
                l = [
                    '<div class="layui-inline" lay-event="add"><i class="layui-icon layui-icon-add-1"></i></div>',
                    '<div class="layui-inline" lay-event="update"><i class="layui-icon layui-icon-edit"></i></div>',
                    '<div class="layui-inline" lay-event="delete"><i class="layui-icon layui-icon-delete"></i></div>'
                ].join(''),
                n = e.layTool.find('.layui-table-tool-temp');
            if ('default' === a.toolbar) n.html(l);
            else if ('string' == typeof a.toolbar) {
                var o = t(a.toolbar).html() || '';
                o && n.html(i(o).render(a))
            }
            var r = {
                    filter: {
                        title: '筛选列',
                        layEvent: 'LAYTABLE_COLS',
                        icon: 'layui-icon-cols'
                    },
                    exports: {
                        title: '导出',
                        layEvent: 'LAYTABLE_EXPORT',
                        icon: 'layui-icon-export'
                    },
                    print: {
                        title: '打印',
                        layEvent: 'LAYTABLE_PRINT',
                        icon: 'layui-icon-print'
                    }
                },
                d = [];
            'object' == typeof a.defaultToolbar && layui.each(a.defaultToolbar, function (e, t) {
                var i = 'string' == typeof t ? r[t] : t;
                i && d.push('<div class="layui-inline" title="' + i.title + '" lay-event="' + i.layEvent + '"><i class="layui-icon ' + i.icon + '"></i></div>')
            }),
                e.layTool.find('.layui-table-tool-self').html(d.join(''))
        },
        j.prototype.setParentCol = function (e, t) {
            var i = this,
                a = i.config,
                l = i.layHeader.find('th[data-key="' + a.index + '-' + t + '"]'),
                n = parseInt(l.attr('colspan')) || 0;
            if (l[0]) {
                var o = t.split('-'),
                    r = a.cols[o[0]][o[1]];
                e ? n-- : n++,
                    l.attr('colspan', n),
                    l[n < 1 ? 'addClass' : 'removeClass'](f),
                    r.colspan = n,
                    r.hide = n < 1;
                var d = l.data('parentkey');
                d && i.setParentCol(e, d)
            }
        },
        j.prototype.setColsPatch = function () {
            var e = this,
                t = e.config;
            layui.each(t.cols, function (t, i) {
                layui.each(i, function (t, i) {
                    i.hide && e.setParentCol(i.hide, i.parentKey)
                })
            })
        },
        j.prototype.setColsWidth = function () {
            var e = this,
                t = e.config,
                i = 0,
                a = 0,
                l = 0,
                n = 0,
                o = e.setInit('width');
            e.eachCols(function (e, t) {
                t.hide || i++
            }),
                o = o - function () {
                    return 'line' === t.skin || 'nob' === t.skin ? 2 : i + 1
                }() - e.getScrollWidth(e.layMain[0]) - 1;
            var r = function (e) {
                layui.each(t.cols, function (i, r) {
                    layui.each(r, function (i, d) {
                        var c = 0,
                            s = d.minWidth || t.cellMinWidth;
                        return d ? void (d.colGroup || d.hide || (e ? l && l < s && (a--, c = s) : (c = d.width || 0, /\d+%$/.test(c) ? (c = Math.floor(parseFloat(c) / 100 * o), c < s && (c = s)) : c || (d.width = c = 0, a++)), d.hide && (c = 0), n += c)) : void r.splice(i, 1)
                    })
                }),
                o > n && a && (l = (o - n) / a)
            };
            r(),
                r(!0),
                e.autoColNums = a,
                e.eachCols(function (i, a) {
                    var n = a.minWidth || t.cellMinWidth;
                    a.colGroup || a.hide || (0 === a.width ? e.getCssRule(t.index + '-' + a.key, function (e) {
                        e.style.width = Math.floor(l >= n ? l : n) + 'px'
                    }) : /\d+%$/.test(a.width) && e.getCssRule(t.index + '-' + a.key, function (e) {
                        e.style.width = Math.floor(parseFloat(a.width) / 100 * o) + 'px'
                    }))
                });
            var d = e.layMain.width() - e.getScrollWidth(e.layMain[0]) - e.layMain.children('table').outerWidth();
            if (e.autoColNums && d >= -i && d <= i) {
                var c = function (t) {
                        var i;
                        return t = t || e.layHeader.eq(0).find('thead th:last-child'),
                            i = t.data('field'),
                            !i && t.prev() [0] ? c(t.prev()) : t
                    },
                    s = c(),
                    u = s.data('key');
                e.getCssRule(u, function (t) {
                    var i = t.style.width || s.outerWidth();
                    t.style.width = parseFloat(i) + d + 'px',
                    e.layMain.height() - e.layMain.prop('clientHeight') > 0 && (t.style.width = parseFloat(t.style.width) - 1 + 'px')
                })
            }
            e.loading(!0)
        },
        j.prototype.resize = function () {
            var e = this;
            e.fullSize(),
                e.setColsWidth(),
                e.scrollPatch()
        },
        j.prototype.reload = function (e) {
            var i = this;
            e = e || {},
                delete i.haveInit,
            e.data && e.data.constructor === Array && delete i.config.data,
                i.config = t.extend(!0, {}, i.config, e),
                i.render()
        },
        j.prototype.errorView = function (e) {
            var i = this,
                a = i.layMain.find('.' + p),
                l = t('<div class="' + p + '">' + (e || 'Error') + '</div>');
            a[0] && (i.layNone.remove(), a.remove()),
                i.layFixed.addClass(f),
                i.layMain.find('tbody').html(''),
                i.layMain.append(i.layNone = l),
                d.cache[i.key] = []
        },
        j.prototype.page = 1,
        j.prototype.pullData = function (e) {
            var i = this,
                a = i.config,
                l = a.request,
                n = a.response,
                o = function () {
                    'object' == typeof a.initSort && i.sort(a.initSort.field, a.initSort.type)
                };
            if (i.startTime = (new Date).getTime(), a.url) {
                var r = {};
                r[l.pageName] = e,
                    r[l.limitName] = a.limit;
                var d = t.extend(r, a.where);
                a.contentType && 0 == a.contentType.indexOf('application/json') && (d = JSON.stringify(d)),
                    i.loading(),
                    t.ajax({
                        type: a.method || 'get',
                        url: a.url,
                        contentType: a.contentType,
                        data: d,
                        dataType: 'json',
                        headers: a.headers || {},
                        success: function (t) {
                            'function' == typeof a.parseData && (t = a.parseData(t) || t),
                                t[n.statusName] != n.statusCode ? (i.renderForm(), i.errorView(t[n.msgName] || '返回的数据不符合规范，正确的成功状态码应为："' + n.statusName + '": ' + n.statusCode)) : (i.renderData(t, e, t[n.countName]), o(), a.time = (new Date).getTime() - i.startTime + ' ms'),
                                i.setColsWidth(),
                            'function' == typeof a.done && a.done(t, e, t[n.countName])
                        },
                        error: function (e, t) {
                            i.errorView('数据接口请求异常：' + t),
                                i.renderForm(),
                                i.setColsWidth()
                        }
                    })
            } else if (a.data && a.data.constructor === Array) {
                var c = {},
                    s = e * a.limit - a.limit;
                c[n.dataName] = a.data.concat().splice(s, a.limit),
                    c[n.countName] = a.data.length,
                    i.renderData(c, e, c[n.countName]),
                    o(),
                    i.setColsWidth(),
                'function' == typeof a.done && a.done(c, e, c[n.countName])
            }
        },
        j.prototype.eachCols = function (e) {
            var t = this;
            return d.eachCols(null, e, t.config.cols),
                t
        },
        j.prototype.renderData = function (e, n, o, r) {
            var c = this,
                s = c.config,
                y = e[s.response.dataName] || [],
                h = [],
                v = [],
                m = [],
                g = function () {
                    var e;
                    return !r && c.sortKey ? c.sort(c.sortKey.field, c.sortKey.sort, !0) : (layui.each(y, function (a, l) {
                        var o = [],
                            y = [],
                            p = [],
                            g = a + s.limit * (n - 1) + 1;
                        0 !== l.length && (r || (l[d.config.indexName] = a), c.eachCols(function (n, r) {
                            var c = r.field || n,
                                h = s.index + '-' + r.key,
                                v = l[c];
                            if (void 0 !== v && null !== v || (v = ''), !r.colGroup) {
                                var m = [
                                    '<td data-field="' + c + '" data-key="' + h + '" ' + function () {
                                        var e = [];
                                        return r.edit && e.push('data-edit="' + r.edit + '"'),
                                        r.align && e.push('align="' + r.align + '"'),
                                        r.templet && e.push('data-content="' + v + '"'),
                                        r.toolbar && e.push('data-off="true"'),
                                        r.event && e.push('lay-event="' + r.event + '"'),
                                        r.style && e.push('style="' + r.style + '"'),
                                        r.minWidth && e.push('data-minwidth="' + r.minWidth + '"'),
                                            e.join(' ')
                                    }() + ' class="' + function () {
                                        var e = [];
                                        return r.hide && e.push(f),
                                        r.field || e.push('layui-table-col-special'),
                                            e.join(' ')
                                    }() + '">',
                                    '<div class="layui-table-cell laytable-cell-' + function () {
                                        return 'normal' === r.type ? h : h + ' laytable-cell-' + r.type
                                    }() + '">' + function () {
                                        var n = t.extend(!0, {
                                                LAY_INDEX: g
                                            }, l),
                                            o = d.config.checkName;
                                        switch (r.type) {
                                            case 'checkbox':
                                                return '<input type="checkbox" name="layTableCheckbox" lay-skin="primary" ' + function () {
                                                    return r[o] ? (l[o] = r[o], r[o] ? 'checked' : '') : n[o] ? 'checked' : ''
                                                }() + '>';
                                            case 'radio':
                                                return n[o] && (e = a),
                                                '<input type="radio" name="layTableRadio_' + s.index + '" ' + (n[o] ? 'checked' : '') + ' lay-type="layTableRadio">';
                                            case 'numbers':
                                                return g
                                        }
                                        return r.toolbar ? i(t(r.toolbar).html() || '').render(n) : u(r, v, n)
                                    }(),
                                    '</div></td>'].join('');
                                o.push(m),
                                r.fixed && 'right' !== r.fixed && y.push(m),
                                'right' === r.fixed && p.push(m)
                            }
                        }), h.push('<tr data-index="' + a + '">' + o.join('') + '</tr>'), v.push('<tr data-index="' + a + '">' + y.join('') + '</tr>'), m.push('<tr data-index="' + a + '">' + p.join('') + '</tr>'))
                    }), c.layBody.scrollTop(0), c.layMain.find('.' + p).remove(), c.layMain.find('tbody').html(h.join('')), c.layFixLeft.find('tbody').html(v.join('')), c.layFixRight.find('tbody').html(m.join('')), c.renderForm(), 'number' == typeof e && c.setThisRowChecked(e), c.syncCheckAll(), c.haveInit ? c.scrollPatch() : setTimeout(function () {
                        c.scrollPatch()
                    }, 50), c.haveInit = !0, l.close(c.tipsIndex), s.HAS_SET_COLS_PATCH || c.setColsPatch(), void (s.HAS_SET_COLS_PATCH = !0))
                };
            return d.cache[c.key] = y,
                c.layPage[0 == o || 0 === y.length && 1 == n ? 'addClass' : 'removeClass'](f),
                r ? g() : 0 === y.length ? (c.renderForm(), c.errorView(s.text.none)) : (c.layFixed.removeClass(f), g(), c.renderTotal(y), void (s.page && (s.page = t.extend({
                    elem: 'layui-table-page' + s.index,
                    count: o,
                    limit: s.limit,
                    limits: s.limits || [
                        10,
                        20,
                        30,
                        40,
                        50,
                        60,
                        70,
                        80,
                        90
                    ],
                    groups: 3,
                    layout: [
                        'prev',
                        'page',
                        'next',
                        'skip',
                        'count',
                        'limit'
                    ],
                    prev: '<i class="layui-icon">&#xe603;</i>',
                    next: '<i class="layui-icon">&#xe602;</i>',
                    jump: function (e, t) {
                        t || (c.page = e.curr, s.limit = e.limit, c.pullData(e.curr))
                    }
                }, s.page), s.page.count = o, a.render(s.page))))
        },
        j.prototype.renderTotal = function (e) {
            var t = this,
                i = t.config,
                a = {};
            if (i.totalRow) {
                layui.each(e, function (e, i) {
                    0 !== i.length && t.eachCols(function (e, t) {
                        var l = t.field || e,
                            n = i[l];
                        t.totalRow && (a[l] = (a[l] || 0) + (parseFloat(n) || 0))
                    })
                }),
                    t.dataTotal = {};
                var l = [];
                t.eachCols(function (e, n) {
                    var o = n.field || e,
                        r = function () {
                            var e = n.totalRowText || '',
                                t = parseFloat(a[o]).toFixed(2),
                                i = {};
                            return i[o] = t,
                                t = u(n, t, i),
                                n.totalRow ? t || e : e
                        }(),
                        d = [
                            '<td data-field="' + o + '" data-key="' + i.index + '-' + n.key + '" ' + function () {
                                var e = [];
                                return n.align && e.push('align="' + n.align + '"'),
                                n.style && e.push('style="' + n.style + '"'),
                                n.minWidth && e.push('data-minwidth="' + n.minWidth + '"'),
                                    e.join(' ')
                            }() + ' class="' + function () {
                                var e = [];
                                return n.hide && e.push(f),
                                n.field || e.push('layui-table-col-special'),
                                    e.join(' ')
                            }() + '">',
                            '<div class="layui-table-cell laytable-cell-' + function () {
                                var e = i.index + '-' + n.key;
                                return 'normal' === n.type ? e : e + ' laytable-cell-' + n.type
                            }() + '">' + r,
                            '</div></td>'
                        ].join('');
                    n.field && (t.dataTotal[o] = r),
                        l.push(d)
                }),
                    t.layTotal.find('tbody').html('<tr>' + l.join('') + '</tr>')
            }
        },
        j.prototype.getColElem = function (e, t) {
            var i = this,
                a = i.config;
            return e.eq(0).find('.laytable-cell-' + (a.index + '-' + t) + ':eq(0)')
        },
        j.prototype.renderForm = function (e) {
            n.render(e, 'LAY-table-' + this.index)
        },
        j.prototype.setThisRowChecked = function (e) {
            var t = this,
                i = (t.config, 'layui-table-click'),
                a = t.layBody.find('tr[data-index="' + e + '"]');
            a.addClass(i).siblings('tr').removeClass(i)
        },
        j.prototype.sort = function (e, i, a, l) {
            var n,
                r,
                c = this,
                s = {},
                u = c.config,
                h = u.elem.attr('lay-filter'),
                f = d.cache[c.key];
            'string' == typeof e && c.layHeader.find('th').each(function (i, a) {
                var l = t(this),
                    o = l.data('field');
                if (o === e) return e = l,
                    n = o,
                    !1
            });
            try {
                var n = n || e.data('field'),
                    p = e.data('key');
                if (c.sortKey && !a && n === c.sortKey.field && i === c.sortKey.sort) return;
                var v = c.layHeader.find('th .laytable-cell-' + p).find(S);
                c.layHeader.find('th').find(S).removeAttr('lay-sort'),
                    v.attr('lay-sort', i || null),
                    c.layFixed.find('th')
            } catch (m) {
                return o.error('Table modules: Did not match to field')
            }
            c.sortKey = {
                field: n,
                sort: i
            },
            u.autoSort && ('asc' === i ? r = layui.sort(f, n) : 'desc' === i ? r = layui.sort(f, n, !0) : (r = layui.sort(f, d.config.indexName), delete c.sortKey)),
                s[u.response.dataName] = r || f,
                c.renderData(s, c.page, c.count, !0),
            l && layui.event.call(e, y, 'sort(' + h + ')', {
                field: n,
                type: i
            })
        },
        j.prototype.loading = function (e) {
            var i = this,
                a = i.config;
            a.loading && (e ? (i.layInit && i.layInit.remove(), delete i.layInit, i.layBox.find(b).remove()) : (i.layInit = t(['<div class="layui-table-init">',
                '<i class="layui-icon layui-icon-loading layui-anim layui-anim-rotate layui-anim-loop"></i>',
                '</div>'].join('')), i.layBox.append(i.layInit)))
        },
        j.prototype.setCheckData = function (e, t) {
            var i = this,
                a = i.config,
                l = d.cache[i.key];
            l[e] && l[e].constructor !== Array && (l[e][a.checkName] = t)
        },
        j.prototype.syncCheckAll = function () {
            var e = this,
                t = e.config,
                i = e.layHeader.find('input[name="layTableCheckbox"]'),
                a = function (i) {
                    return e.eachCols(function (e, a) {
                        'checkbox' === a.type && (a[t.checkName] = i)
                    }),
                        i
                };
            i[0] && (d.checkStatus(e.key).isAll ? (i[0].checked || (i.prop('checked', !0), e.renderForm('checkbox')), a(!0)) : (i[0].checked && (i.prop('checked', !1), e.renderForm('checkbox')), a(!1)))
        },
        j.prototype.getCssRule = function (e, t) {
            var i = this,
                a = i.elem.find('style') [0],
                l = a.sheet || a.styleSheet || {},
                n = l.cssRules || l.rules;
            layui.each(n, function (i, a) {
                if (a.selectorText === '.laytable-cell-' + e) return t(a),
                    !0
            })
        },
        j.prototype.fullSize = function () {
            var e,
                t = this,
                i = t.config,
                a = i.height;
            t.fullHeightGap && (a = R.height() - t.fullHeightGap, a < 135 && (a = 135), t.elem.css('height', a)),
            a && (e = parseFloat(a) - (t.layHeader.outerHeight() || 38), i.toolbar && (e -= t.layTool.outerHeight() || 50), i.totalRow && (e -= t.layTotal.outerHeight() || 40), i.page && (e -= t.layPage.outerHeight() || 41), t.layMain.css('height', e - 2))
        },
        j.prototype.getScrollWidth = function (e) {
            var t = 0;
            return e ? t = e.offsetWidth - e.clientWidth : (e = document.createElement('div'), e.style.width = '100px', e.style.height = '100px', e.style.overflowY = 'scroll', document.body.appendChild(e), t = e.offsetWidth - e.clientWidth, document.body.removeChild(e)),
                t
        },
        j.prototype.scrollPatch = function () {
            var e = this,
                i = e.layMain.children('table'),
                a = e.layMain.width() - e.layMain.prop('clientWidth'),
                l = e.layMain.height() - e.layMain.prop('clientHeight'),
                n = (e.getScrollWidth(e.layMain[0]), i.outerWidth() - e.layMain.width()),
                o = function (e) {
                    if (a && l) {
                        if (e = e.eq(0), !e.find('.layui-table-patch') [0]) {
                            var i = t('<th class="layui-table-patch"><div class="layui-table-cell"></div></th>');
                            i.find('div').css({
                                width: a
                            }),
                                e.find('tr').append(i)
                        }
                    } else e.find('.layui-table-patch').remove()
                };
            o(e.layHeader),
                o(e.layTotal);
            var r = e.layMain.height(),
                d = r - l;
            e.layFixed.find(k).css('height', i.height() >= d ? d : 'auto'),
                e.layFixRight[n > 0 ? 'removeClass' : 'addClass'](f),
                e.layFixRight.css('right', a - 1)
        },
        j.prototype.events = function () {
            var e,
                i = this,
                a = i.config,
                o = t('body'),
                c = {},
                s = i.layHeader.find('th'),
                h = '.layui-table-cell',
                p = a.elem.attr('lay-filter');
            i.layTool.on('click', '*[lay-event]', function (e) {
                var o = t(this),
                    c = o.attr('lay-event'),
                    s = function (e) {
                        var l = t(e.list),
                            n = t('<ul class="layui-table-tool-panel"></ul>');
                        n.html(l),
                        a.height && n.css('max-height', a.height - (i.layTool.outerHeight() || 50)),
                        o.find('.layui-table-tool-panel') [0] || o.append(n),
                            i.renderForm(),
                            n.on('click', function (e) {
                                layui.stope(e)
                            }),
                        e.done && e.done(n, l)
                    };
                switch (layui.stope(e), F.trigger('table.tool.panel.remove'), l.close(i.tipsIndex), c) {
                    case 'LAYTABLE_COLS':
                        s({
                            list: function () {
                                var e = [];
                                return i.eachCols(function (t, i) {
                                    i.field && 'normal' == i.type && e.push('<li><input type="checkbox" name="' + i.field + '" data-key="' + i.key + '" data-parentkey="' + (i.parentKey || '') + '" lay-skin="primary" ' + (i.hide ? '' : 'checked') + ' title="' + (i.title || i.field) + '" lay-filter="LAY_TABLE_TOOL_COLS"></li>')
                                }),
                                    e.join('')
                            }(),
                            done: function () {
                                n.on('checkbox(LAY_TABLE_TOOL_COLS)', function (e) {
                                    var l = t(e.elem),
                                        n = this.checked,
                                        o = l.data('key'),
                                        r = l.data('parentkey');
                                    layui.each(a.cols, function (e, t) {
                                        layui.each(t, function (t, l) {
                                            if (e + '-' + t === o) {
                                                var d = l.hide;
                                                l.hide = !n,
                                                    i.elem.find('*[data-key="' + a.index + '-' + o + '"]') [n ? 'removeClass' : 'addClass'](f),
                                                d != l.hide && i.setParentCol(!n, r),
                                                    i.resize()
                                            }
                                        })
                                    })
                                })
                            }
                        });
                        break;
                    case 'LAYTABLE_EXPORT':
                        r.ie ? l.tips('导出功能不支持 IE，请用 Chrome 等高级浏览器导出', this, {
                            tips: 3
                        }) : s({
                            list: function () {
                                return ['<li data-type="csv">导出到 Csv 文件</li>',
                                    '<li data-type="xls">导出到 Excel 文件</li>'].join('')
                            }(),
                            done: function (e, l) {
                                l.on('click', function () {
                                    var e = t(this).data('type');
                                    d.exportFile.call(i, a.id, null, e)
                                })
                            }
                        });
                        break;
                    case 'LAYTABLE_PRINT':
                        var u = window.open('打印窗口', '_blank'),
                            h = [
                                '<style>',
                                'body{font-size: 12px; color: #666;}',
                                'table{width: 100%; border-collapse: collapse; border-spacing: 0;}',
                                'th,td{line-height: 20px; padding: 9px 15px; border: 1px solid #ccc; text-align: left; font-size: 12px; color: #666;}',
                                'a{color: #666; text-decoration:none;}',
                                '*.layui-hide{display: none}',
                                '</style>'
                            ].join(''),
                            v = t(i.layHeader.html());
                        v.append(i.layMain.find('table').html()),
                            v.append(i.layTotal.find('table').html()),
                            v.find('th.layui-table-patch').remove(),
                            v.find('.layui-table-col-special').remove(),
                            u.document.write(h + v.prop('outerHTML')),
                            u.document.close(),
                            u.print(),
                            u.close()
                }
                layui.event.call(this, y, 'toolbar(' + p + ')', t.extend({
                    event: c,
                    config: a
                }, {}))
            }), s.on('mousemove', function (e) {
                var i = t(this),
                    a = i.offset().left,
                    l = e.clientX - a;
                i.data('unresize') || c.resizeStart || (c.allowResize = i.width() - l <= 10, o.css('cursor', c.allowResize ? 'col-resize' : ''))
            }).on('mouseleave', function () {
                t(this);
                c.resizeStart || o.css('cursor', '')
            }).on('mousedown', function (e) {
                var l = t(this);
                if (c.allowResize) {
                    var n = l.data('key');
                    e.preventDefault(),
                        c.resizeStart = !0,
                        c.offset = [
                            e.clientX,
                            e.clientY
                        ],
                        i.getCssRule(n, function (e) {
                            var t = e.style.width || l.outerWidth();
                            c.rule = e,
                                c.ruleWidth = parseFloat(t),
                                c.minWidth = l.data('minwidth') || a.cellMinWidth
                        })
                }
            }), F.on('mousemove', function (t) {
                if (c.resizeStart) {
                    if (t.preventDefault(), c.rule) {
                        var a = c.ruleWidth + t.clientX - c.offset[0];
                        a < c.minWidth && (a = c.minWidth),
                            c.rule.style.width = a + 'px',
                            l.close(i.tipsIndex)
                    }
                    e = 1
                }
            }).on('mouseup', function (t) {
                c.resizeStart && (c = {}, o.css('cursor', ''), i.scrollPatch()),
                2 === e && (e = null)
            }), s.on('click', function (a) {
                var l,
                    n = t(this),
                    o = n.find(S),
                    r = o.attr('lay-sort');
                return o[0] && 1 !== e ? (l = 'asc' === r ? 'desc' : 'desc' === r ? null : 'asc', void i.sort(n, l, null, !0)) : e = 2
            }).find(S + ' .layui-edge ').on('click', function (e) {
                var a = t(this),
                    l = a.index(),
                    n = a.parents('th').eq(0).data('field');
                layui.stope(e),
                    0 === l ? i.sort(n, 'asc', null, !0) : i.sort(n, 'desc', null, !0)
            });
            var v = function (e) {
                var a = t(this),
                    l = a.parents('tr').eq(0).data('index'),
                    n = i.layBody.find('tr[data-index="' + l + '"]'),
                    o = d.cache[i.key] || [];
                return o = o[l] || {},
                    t.extend({
                        tr: n,
                        data: d.clearCacheKey(o),
                        del: function () {
                            d.cache[i.key][l] = [],
                                n.remove(),
                                i.scrollPatch()
                        },
                        update: function (e) {
                            e = e || {},
                                layui.each(e, function (e, t) {
                                    if (e in o) {
                                        var a,
                                            l = n.children('td[data-field="' + e + '"]');
                                        o[e] = t,
                                            i.eachCols(function (t, i) {
                                                i.field == e && i.templet && (a = i.templet)
                                            }),
                                            l.children(h).html(u({
                                                templet: a
                                            }, t, o)),
                                            l.data('content', t)
                                    }
                                })
                        }
                    }, e)
            };
            i.elem.on('click', 'input[name="layTableCheckbox"]+', function () {
                var e = t(this).prev(),
                    a = i.layBody.find('input[name="layTableCheckbox"]'),
                    l = e.parents('tr').eq(0).data('index'),
                    n = e[0].checked,
                    o = 'layTableAllChoose' === e.attr('lay-filter');
                o ? (a.each(function (e, t) {
                    t.checked = n,
                        i.setCheckData(e, n)
                }), i.syncCheckAll(), i.renderForm('checkbox')) : (i.setCheckData(l, n), i.syncCheckAll()),
                    layui.event.call(e[0], y, 'checkbox(' + p + ')', v.call(e[0], {
                        checked: n,
                        type: o ? 'all' : 'one'
                    }))
            }), i.elem.on('click', 'input[lay-type="layTableRadio"]+', function () {
                var e = t(this).prev(),
                    a = e[0].checked,
                    l = d.cache[i.key],
                    n = e.parents('tr').eq(0).data('index');
                layui.each(l, function (e, t) {
                    n === e ? t.LAY_CHECKED = !0 : delete t.LAY_CHECKED
                }),
                    i.setThisRowChecked(n),
                    layui.event.call(this, y, 'radio(' + p + ')', v.call(this, {
                        checked: a
                    }))
            }), i.layBody.on('mouseenter', 'tr', function () {
                var e = t(this),
                    a = e.index();
                e.data('off') || i.layBody.find('tr:eq(' + a + ')').addClass(_)
            }).on('mouseleave', 'tr', function () {
                var e = t(this),
                    a = e.index();
                e.data('off') || i.layBody.find('tr:eq(' + a + ')').removeClass(_)
            }).on('click', 'tr', function () {
                m.call(this, 'row')
            }).on('dblclick', 'tr', function () {
                m.call(this, 'rowDouble')
            });
            var m = function (e) {
                var i = t(this);
                i.data('off') || layui.event.call(this, y, e + '(' + p + ')', v.call(i.children('td') [0]))
            };
            i.layBody.on('change', '.' + W, function () {
                var e = t(this),
                    a = this.value,
                    l = e.parent().data('field'),
                    n = e.parents('tr').eq(0).data('index'),
                    o = d.cache[i.key][n];
                o[l] = a,
                    layui.event.call(this, y, 'edit(' + p + ')', v.call(this, {
                        value: a,
                        field: l
                    }))
            }).on('blur', '.' + W, function () {
                var e,
                    a = t(this),
                    l = this,
                    n = a.parent().data('field'),
                    o = a.parents('tr').eq(0).data('index'),
                    r = d.cache[i.key][o];
                i.eachCols(function (t, i) {
                    i.field == n && i.templet && (e = i.templet)
                }),
                    a.siblings(h).html(function (t) {
                        return u({
                            templet: e
                        }, t, r)
                    }(l.value)),
                    a.parent().data('content', l.value),
                    a.remove()
            }), i.layBody.on('click', 'td', function (e) {
                var i = t(this),
                    a = (i.data('field'), i.data('edit')),
                    l = i.children(h);
                if (!i.data('off') && a) {
                    var n = t('<input class="layui-input ' + W + '">');
                    return n[0].value = i.data('content') || l.text(),
                    i.find('.' + W) [0] || i.append(n),
                        n.focus(),
                        void layui.stope(e)
                }
            }).on('mouseenter', 'td', function () {
                b.call(this)
            }).on('mouseleave', 'td', function () {
                b.call(this, 'hide')
            });
            var g = 'layui-table-grid-down', b = function (e) {
                var i = t(this),
                    a = i.children(h);
                if (!i.data('off')) if (e) i.find('.layui-table-grid-down').remove();
                else if (a.prop('scrollWidth') > a.outerWidth()) {
                    if (a.find('.' + g) [0]) return;
                    i.append('<div class="' + g + '"><i class="layui-icon layui-icon-down"></i></div>')
                }
            };
            i.layBody.on('click', '.' + g, function (e) {
                var n = t(this),
                    o = n.parent(),
                    d = o.children(h);
                i.tipsIndex = l.tips(['<div class="layui-table-tips-main" style="margin-top: -' + (d.height() + 16) + 'px;' + function () {
                    return 'sm' === a.size ? 'padding: 4px 15px; font-size: 12px;' : 'lg' === a.size ? 'padding: 14px 15px;' : ''
                }() + '">',
                    d.html(),
                    '</div>',
                    '<i class="layui-icon layui-table-tips-c layui-icon-close"></i>'].join(''), d[0], {
                    tips: [
                        3,
                        ''
                    ],
                    time: -1,
                    anim: -1,
                    maxWidth: r.ios || r.android ? 300 : i.elem.width() / 2,
                    isOutAnim: !1,
                    skin: 'layui-table-tips',
                    success: function (e, t) {
                        e.find('.layui-table-tips-c').on('click', function () {
                            l.close(t)
                        })
                    }
                }),
                    layui.stope(e)
            }), i.layBody.on('click', '*[lay-event]', function () {
                var e = t(this),
                    a = e.parents('tr').eq(0).data('index');
                layui.event.call(this, y, 'tool(' + p + ')', v.call(this, {
                    event: e.attr('lay-event')
                })),
                    i.setThisRowChecked(a)
            }), i.layMain.on('scroll', function () {
                var e = t(this),
                    a = e.scrollLeft(),
                    n = e.scrollTop();
                i.layHeader.scrollLeft(a),
                    i.layTotal.scrollLeft(a),
                    i.layFixed.find(k).scrollTop(n),
                    l.close(i.tipsIndex)
            }), R.on('resize', function () {
                i.resize()
            })
        },
        function () {
            F.on('click', function () {
                F.trigger('table.remove.tool.panel')
            }),
                F.on('table.remove.tool.panel', function () {
                    t('.layui-table-tool-panel').remove()
                })
        }(),
        d.init = function (e, i) {
            i = i || {};
            var a = this,
                l = t(e ? 'table[lay-filter="' + e + '"]' : h + '[lay-data]'),
                n = 'Table element property lay-data configuration item has a syntax error: ';
            return l.each(function () {
                var a = t(this),
                    l = a.attr('lay-data');
                try {
                    l = new Function('return ' + l)()
                } catch (r) {
                    o.error(n + l)
                }
                var c = [],
                    s = t.extend({
                        elem: this,
                        cols: [],
                        data: [],
                        skin: a.attr('lay-skin'),
                        size: a.attr('lay-size'),
                        even: 'string' == typeof a.attr('lay-even')
                    }, d.config, i, l);
                e && a.hide(),
                    a.find('thead>tr').each(function (e) {
                        s.cols[e] = [],
                            t(this).children().each(function (i) {
                                var a = t(this),
                                    l = a.attr('lay-data');
                                try {
                                    l = new Function('return ' + l)()
                                } catch (r) {
                                    return o.error(n + l)
                                }
                                var d = t.extend({
                                    title: a.text(),
                                    colspan: a.attr('colspan') || 0,
                                    rowspan: a.attr('rowspan') || 0
                                }, l);
                                d.colspan < 2 && c.push(d),
                                    s.cols[e].push(d)
                            })
                    }),
                    a.find('tbody>tr').each(function (e) {
                        var i = t(this),
                            a = {};
                        i.children('td').each(function (e, i) {
                            var l = t(this),
                                n = l.data('field');
                            if (n) return a[n] = l.html()
                        }),
                            layui.each(c, function (e, t) {
                                var l = i.children('td').eq(e);
                                a[t.field] = l.html()
                            }),
                            s.data[e] = a
                    }),
                    d.render(s)
            }),
                a
        },
        c.that = {},
        c.config = {},
        d.eachCols = function (e, i, a) {
            var l = c.config[e] || {},
                n = [],
                o = 0;
            a = t.extend(!0, [], a || l.cols),
                layui.each(a, function (e, t) {
                    layui.each(t, function (t, i) {
                        if (i.colGroup) {
                            var l = 0;
                            o++,
                                i.CHILD_COLS = [],
                                layui.each(a[e + 1], function (e, t) {
                                    t.PARENT_COL_INDEX || l > 1 && l == i.colspan || (t.PARENT_COL_INDEX = o, i.CHILD_COLS.push(t), l += parseInt(t.colspan > 1 ? t.colspan : 1))
                                })
                        }
                        i.PARENT_COL_INDEX || n.push(i)
                    })
                });
            var r = function (e) {
                layui.each(e || n, function (e, t) {
                    return t.CHILD_COLS ? r(t.CHILD_COLS) : void ('function' == typeof i && i(e, t))
                })
            };
            r()
        },
        d.checkStatus = function (e) {
            var t = 0,
                i = 0,
                a = [],
                l = d.cache[e] || [];
            return layui.each(l, function (e, l) {
                return l.constructor === Array ? void i++ : void (l[d.config.checkName] && (t++, a.push(d.clearCacheKey(l))))
            }),
                {
                    data: a,
                    isAll: !!l.length && t === l.length - i
                }
        },
        d.exportFile = function (e, t, i, fileName) {  // 增加fileName参数
            var a = this;
            t = t || d.clearCacheKey(d.cache[e]);
            i = 'xlsx'; // 强制设置为xlsx格式
            var l = c.config[e] || {},
                n = {
                    csv: 'text/csv',
                    xls: 'application/vnd.ms-excel',
                    xlsx: 'application/vnd.openxmlformats-officedocument.spreadsheetml.sheet' // 添加xlsx类型
                }[i],
                s = document.createElement('a');

            return r.ie ? o.error('IE_NOT_SUPPORT_EXPORTS') : (s.href = 'data:' + n + ';charset=utf-8,﻿' + encodeURIComponent(function () {
                var i = [],
                    l = [],
                    n = [];
                return layui.each(t, function (t, a) {
                    var n = [];
                    'object' == typeof e ? (layui.each(e, function (e, a) {
                        0 == t && i.push(a || '')
                    }), layui.each(d.clearCacheKey(a), function (e, t) {
                        n.push('"' + (t || '') + '"')
                    })) : d.eachCols(e, function (e, l) {
                        if (l.field && 'normal' == l.type && !l.hide) {
                            var o = a[l.field];
                            void 0 !== o && null !== o || (o = ''),
                            0 == t && i.push(l.title || ''),
                                n.push('"' + u(l, o, a, 'text') + '"')
                        }
                    }),
                        l.push(n.join(','))
                }),
                    layui.each(a.dataTotal, function (e, t) {
                        n.push(t)
                    }),
                i.join(',') + '\r\n' + l.join('\r\n') + '\r\n' + n.join(',')
            }()),
                s.download = (fileName || l.title || 'table_' + (l.index || '')) + '.xlsx', // 使用传入的文件名，默认使用表格标题
                document.body.appendChild(s),
                s.click(),
                void document.body.removeChild(s))

        },
        d.resize = function (e) {
            if (e) {
                var t = s(e);
                if (!t) return;
                c.that[e].resize()
            } else layui.each(c.that, function () {
                this.resize()
            })
        },
        d.reload = function (e, t) {
            var i = s(e);
            if (i) {
                var a = c.that[e];
                return a.reload(t),
                    c.call(a)
            }
        },
        d.render = function (e) {
            var t = new j(e);
            return c.call(t)
        },
        d.clearCacheKey = function (e) {
            return e = t.extend({}, e),
                delete e[d.config.checkName],
                delete e[d.config.indexName],
                e
        },
        d.init(),
        e(y, d)
});
layui.define('jquery', function (e) {
    'use strict';
    var i = layui.$,
        n = (layui.hint(), layui.device(), {
            config: {},
            set: function (e) {
                var n = this;
                return n.config = i.extend({}, n.config, e),
                    n
            },
            on: function (e, i) {
                return layui.onevent.call(this, t, e, i)
            }
        }),
        t = 'carousel',
        a = 'layui-this',
        l = '>*[carousel-item]>*',
        o = 'layui-carousel-left',
        r = 'layui-carousel-right',
        d = 'layui-carousel-prev',
        s = 'layui-carousel-next',
        u = 'layui-carousel-arrow',
        c = 'layui-carousel-ind',
        m = function (e) {
            var t = this;
            t.config = i.extend({}, t.config, n.config, e),
                t.render()
        };
    m.prototype.config = {
        width: '600px',
        height: '280px',
        full: !1,
        arrow: 'hover',
        indicator: 'inside',
        autoplay: !0,
        interval: 3000,
        anim: '',
        trigger: 'click',
        index: 0
    },
        m.prototype.render = function () {
            var e = this,
                n = e.config;
            n.elem = i(n.elem),
            n.elem[0] && (e.elemItem = n.elem.find(l), n.index < 0 && (n.index = 0), n.index >= e.elemItem.length && (n.index = e.elemItem.length - 1), n.interval < 800 && (n.interval = 800), n.full ? n.elem.css({
                position: 'fixed',
                width: '100%',
                height: '100%',
                zIndex: 9999
            }) : n.elem.css({
                width: n.width,
                height: n.height
            }), n.elem.attr('lay-anim', n.anim), e.elemItem.eq(n.index).addClass(a), e.elemItem.length <= 1 || (e.indicator(), e.arrow(), e.autoplay(), e.events()))
        },
        m.prototype.reload = function (e) {
            var n = this;
            clearInterval(n.timer),
                n.config = i.extend({}, n.config, e),
                n.render()
        },
        m.prototype.prevIndex = function () {
            var e = this,
                i = e.config,
                n = i.index - 1;
            return n < 0 && (n = e.elemItem.length - 1),
                n
        },
        m.prototype.nextIndex = function () {
            var e = this,
                i = e.config,
                n = i.index + 1;
            return n >= e.elemItem.length && (n = 0),
                n
        },
        m.prototype.addIndex = function (e) {
            var i = this,
                n = i.config;
            e = e || 1,
                n.index = n.index + e,
            n.index >= i.elemItem.length && (n.index = 0)
        },
        m.prototype.subIndex = function (e) {
            var i = this,
                n = i.config;
            e = e || 1,
                n.index = n.index - e,
            n.index < 0 && (n.index = i.elemItem.length - 1)
        },
        m.prototype.autoplay = function () {
            var e = this,
                i = e.config;
            i.autoplay && (clearInterval(e.timer), e.timer = setInterval(function () {
                e.slide()
            }, i.interval))
        },
        m.prototype.arrow = function () {
            var e = this,
                n = e.config,
                t = i(['<button class="layui-icon ' + u + '" lay-type="sub">' + ('updown' === n.anim ? '&#xe619;' : '&#xe603;') + '</button>',
                    '<button class="layui-icon ' + u + '" lay-type="add">' + ('updown' === n.anim ? '&#xe61a;' : '&#xe602;') + '</button>'].join(''));
            n.elem.attr('lay-arrow', n.arrow),
            n.elem.find('.' + u) [0] && n.elem.find('.' + u).remove(),
                n.elem.append(t),
                t.on('click', function () {
                    var n = i(this),
                        t = n.attr('lay-type');
                    e.slide(t)
                })
        },
        m.prototype.indicator = function () {
            var e = this,
                n = e.config,
                t = e.elemInd = i(['<div class="' + c + '"><ul>',
                    function () {
                        var i = [];
                        return layui.each(e.elemItem, function (e) {
                            i.push('<li' + (n.index === e ? ' class="layui-this"' : '') + '></li>')
                        }),
                            i.join('')
                    }(),
                    '</ul></div>'].join(''));
            n.elem.attr('lay-indicator', n.indicator),
            n.elem.find('.' + c) [0] && n.elem.find('.' + c).remove(),
                n.elem.append(t),
            'updown' === n.anim && t.css('margin-top', -(t.height() / 2)),
                t.find('li').on('hover' === n.trigger ? 'mouseover' : n.trigger, function () {
                    var t = i(this),
                        a = t.index();
                    a > n.index ? e.slide('add', a - n.index) : a < n.index && e.slide('sub', n.index - a)
                })
        },
        m.prototype.slide = function (e, i) {
            var n = this,
                l = n.elemItem,
                u = n.config,
                c = u.index,
                m = u.elem.attr('lay-filter');
            n.haveSlide || ('sub' === e ? (n.subIndex(i), l.eq(u.index).addClass(d), setTimeout(function () {
                l.eq(c).addClass(r),
                    l.eq(u.index).addClass(r)
            }, 50)) : (n.addIndex(i), l.eq(u.index).addClass(s), setTimeout(function () {
                l.eq(c).addClass(o),
                    l.eq(u.index).addClass(o)
            }, 50)), setTimeout(function () {
                l.removeClass(a + ' ' + d + ' ' + s + ' ' + o + ' ' + r),
                    l.eq(u.index).addClass(a),
                    n.haveSlide = !1
            }, 300), n.elemInd.find('li').eq(u.index).addClass(a).siblings().removeClass(a), n.haveSlide = !0, layui.event.call(this, t, 'change(' + m + ')', {
                index: u.index,
                prevIndex: c,
                item: l.eq(u.index)
            }))
        },
        m.prototype.events = function () {
            var e = this,
                i = e.config;
            i.elem.data('haveEvents') || (i.elem.on('mouseenter', function () {
                clearInterval(e.timer)
            }).on('mouseleave', function () {
                e.autoplay()
            }), i.elem.data('haveEvents', !0))
        },
        n.render = function (e) {
            var i = new m(e);
            return i
        },
        e(t, n)
});
layui.define('jquery', function (e) {
    'use strict';
    var a = layui.jquery,
        i = {
            config: {},
            index: layui.rate ? layui.rate.index + 10000 : 0,
            set: function (e) {
                var i = this;
                return i.config = a.extend({}, i.config, e),
                    i
            },
            on: function (e, a) {
                return layui.onevent.call(this, n, e, a)
            }
        },
        l = function () {
            var e = this,
                a = e.config;
            return {
                setvalue: function (a) {
                    e.setvalue.call(e, a)
                },
                config: a
            }
        },
        n = 'rate',
        t = 'layui-rate',
        o = 'layui-icon-rate',
        s = 'layui-icon-rate-solid',
        u = 'layui-icon-rate-half',
        r = 'layui-icon-rate-solid layui-icon-rate-half',
        c = 'layui-icon-rate-solid layui-icon-rate',
        f = 'layui-icon-rate layui-icon-rate-half',
        v = function (e) {
            var l = this;
            l.index = ++i.index,
                l.config = a.extend({}, l.config, i.config, e),
                l.render()
        };
    v.prototype.config = {
        length: 5,
        text: !1,
        readonly: !1,
        half: !1,
        value: 0,
        theme: ''
    },
        v.prototype.render = function () {
            var e = this,
                i = e.config,
                l = i.theme ? 'style="color: ' + i.theme + ';"' : '';
            i.elem = a(i.elem),
            parseInt(i.value) !== i.value && (i.half || (i.value = Math.ceil(i.value) - i.value < 0.5 ? Math.ceil(i.value) : Math.floor(i.value)));
            for (var n = '<ul class="layui-rate" ' + (i.readonly ? 'readonly' : '') + '>', u = 1; u <= i.length; u++) {
                var r = '<li class="layui-inline"><i class="layui-icon ' + (u > Math.floor(i.value) ? o : s) + '" ' + l + '></i></li>';
                i.half && parseInt(i.value) !== i.value && u == Math.ceil(i.value) ? n = n + '<li><i class="layui-icon layui-icon-rate-half" ' + l + '></i></li>' : n += r
            }
            n += '</ul>' + (i.text ? '<span class="layui-inline">' + i.value + '星' : '') + '</span>';
            var c = i.elem,
                f = c.next('.' + t);
            f[0] && f.remove(),
                e.elemTemp = a(n),
                i.span = e.elemTemp.next('span'),
            i.setText && i.setText(i.value),
                c.html(e.elemTemp),
                c.addClass('layui-inline'),
            i.readonly || e.action()
        },
        v.prototype.setvalue = function (e) {
            var a = this,
                i = a.config;
            i.value = e,
                a.render()
        },
        v.prototype.action = function () {
            var e = this,
                i = e.config,
                l = e.elemTemp,
                n = l.find('i').width();
            l.children('li').each(function (e) {
                var t = e + 1,
                    v = a(this);
                v.on('click', function (e) {
                    if (i.value = t, i.half) {
                        var o = e.pageX - a(this).offset().left;
                        o <= n / 2 && (i.value = i.value - 0.5)
                    }
                    i.text && l.next('span').text(i.value + '星'),
                    i.choose && i.choose(i.value),
                    i.setText && i.setText(i.value)
                }),
                    v.on('mousemove', function (e) {
                        if (l.find('i').each(function () {
                            a(this).addClass(o).removeClass(r)
                        }), l.find('i:lt(' + t + ')').each(function () {
                            a(this).addClass(s).removeClass(f)
                        }), i.half) {
                            var c = e.pageX - a(this).offset().left;
                            c <= n / 2 && v.children('i').addClass(u).removeClass(s)
                        }
                    }),
                    v.on('mouseleave', function () {
                        l.find('i').each(function () {
                            a(this).addClass(o).removeClass(r)
                        }),
                            l.find('i:lt(' + Math.floor(i.value) + ')').each(function () {
                                a(this).addClass(s).removeClass(f)
                            }),
                        i.half && parseInt(i.value) !== i.value && l.children('li:eq(' + Math.floor(i.value) + ')').children('i').addClass(u).removeClass(c)
                    })
            })
        },
        v.prototype.events = function () {
            var e = this;
            e.config
        },
        i.render = function (e) {
            var a = new v(e);
            return l.call(a)
        },
        e(n, i)
});
layui.define('jquery', function (t) {
    'use strict';
    var e = layui.$,
        i = {
            fixbar: function (t) {
                var i,
                    n,
                    a = 'layui-fixbar',
                    o = 'layui-fixbar-top',
                    r = e(document),
                    l = e('body');
                t = e.extend({
                    showHeight: 200
                }, t),
                    t.bar1 = t.bar1 === !0 ? '&#xe606;' : t.bar1,
                    t.bar2 = t.bar2 === !0 ? '&#xe607;' : t.bar2,
                    t.bgcolor = t.bgcolor ? 'background-color:' + t.bgcolor : '';
                var c = [
                        t.bar1,
                        t.bar2,
                        '&#xe604;'
                    ],
                    g = e(['<ul class="' + a + '">',
                        t.bar1 ? '<li class="layui-icon" lay-type="bar1" style="' + t.bgcolor + '">' + c[0] + '</li>' : '',
                        t.bar2 ? '<li class="layui-icon" lay-type="bar2" style="' + t.bgcolor + '">' + c[1] + '</li>' : '',
                        '<li class="layui-icon ' + o + '" lay-type="top" style="' + t.bgcolor + '">' + c[2] + '</li>',
                        '</ul>'].join('')),
                    s = g.find('.' + o),
                    u = function () {
                        var e = r.scrollTop();
                        e >= t.showHeight ? i || (s.show(), i = 1) : i && (s.hide(), i = 0)
                    };
                e('.' + a) [0] || ('object' == typeof t.css && g.css(t.css), l.append(g), u(), g.find('li').on('click', function () {
                    var i = e(this),
                        n = i.attr('lay-type');
                    'top' === n && e('html,body').animate({
                        scrollTop: 0
                    }, 200),
                    t.click && t.click.call(this, n)
                }), r.on('scroll', function () {
                    clearTimeout(n),
                        n = setTimeout(function () {
                            u()
                        }, 100)
                }))
            },
            countdown: function (t, e, i) {
                var n = this,
                    a = 'function' == typeof e,
                    o = new Date(t).getTime(),
                    r = new Date(!e || a ? (new Date).getTime() : e).getTime(),
                    l = o - r,
                    c = [
                        Math.floor(l / 86400000),
                        Math.floor(l / 3600000) % 24,
                        Math.floor(l / 60000) % 60,
                        Math.floor(l / 1000) % 60
                    ];
                a && (i = e);
                var g = setTimeout(function () {
                    n.countdown(t, r + 1000, i)
                }, 1000);
                return i && i(l > 0 ? c : [
                    0,
                    0,
                    0,
                    0
                ], e, g),
                l <= 0 && clearTimeout(g),
                    g
            },
            timeAgo: function (t, e) {
                var i = this,
                    n = [
                        [],
                        []
                    ],
                    a = (new Date).getTime() - new Date(t).getTime();
                return a > 691200000 ? (a = new Date(t), n[0][0] = i.digit(a.getFullYear(), 4), n[0][1] = i.digit(a.getMonth() + 1), n[0][2] = i.digit(a.getDate()), e || (n[1][0] = i.digit(a.getHours()), n[1][1] = i.digit(a.getMinutes()), n[1][2] = i.digit(a.getSeconds())), n[0].join('-') + ' ' + n[1].join(':')) : a >= 86400000 ? (a / 1000 / 60 / 60 / 24 | 0) + '天前' : a >= 3600000 ? (a / 1000 / 60 / 60 | 0) + '小时前' : a >= 120000 ? (a / 1000 / 60 | 0) + '分钟前' : a < 0 ? '未来' : '刚刚'
            },
            digit: function (t, e) {
                var i = '';
                t = String(t),
                    e = e || 2;
                for (var n = t.length; n < e; n++) i += '0';
                return t < Math.pow(10, e) ? i + (0 | t) : t
            },
            toDateString: function (t, e) {
                var i = this,
                    n = new Date(t || new Date),
                    a = [
                        i.digit(n.getFullYear(), 4),
                        i.digit(n.getMonth() + 1),
                        i.digit(n.getDate())
                    ],
                    o = [
                        i.digit(n.getHours()),
                        i.digit(n.getMinutes()),
                        i.digit(n.getSeconds())
                    ];
                return e = e || 'yyyy-MM-dd HH:mm:ss',
                    e.replace(/yyyy/g, a[0]).replace(/MM/g, a[1]).replace(/dd/g, a[2]).replace(/HH/g, o[0]).replace(/mm/g, o[1]).replace(/ss/g, o[2])
            },
            escape: function (t) {
                return String(t || '').replace(/&(?!#?[a-zA-Z0-9]+;)/g, '&amp;').replace(/</g, '&lt;').replace(/>/g, '&gt;').replace(/'/g, '&#39;').replace(/"/g, '&quot;')
            },
            event: function (t, n, a) {
                n = i.event[t] = e.extend(!0, i.event[t], n) || {},
                    e('body').on(a || 'click', '*[' + t + ']', function () {
                        var i = e(this),
                            a = i.attr(t);
                        n[a] && n[a].call(this, i)
                    })
            }
        };
    !function (t, e, i) {
        '$:nomunge';

        function n() {
            a = e[l](function () {
                o.each(function () {
                    var e = t(this),
                        i = e.width(),
                        n = e.height(),
                        a = t.data(this, g);
                    (i !== a.w || n !== a.h) && e.trigger(c, [
                        a.w = i,
                        a.h = n
                    ])
                }),
                    n()
            }, r[s])
        }

        var a,
            o = t([]),
            r = t.resize = t.extend(t.resize, {}),
            l = 'setTimeout',
            c = 'resize',
            g = c + '-special-event',
            s = 'delay',
            u = 'throttleWindow';
        r[s] = 250,
            r[u] = !0,
            t.event.special[c] = {
                setup: function () {
                    if (!r[u] && this[l]) return !1;
                    var e = t(this);
                    o = o.add(e),
                        t.data(this, g, {
                            w: e.width(),
                            h: e.height()
                        }),
                    1 === o.length && n()
                },
                teardown: function () {
                    if (!r[u] && this[l]) return !1;
                    var e = t(this);
                    o = o.not(e),
                        e.removeData(g),
                    o.length || clearTimeout(a)
                },
                add: function (e) {
                    function n(e, n, o) {
                        var r = t(this),
                            l = t.data(this, g) || {};
                        l.w = n !== i ? n : r.width(),
                            l.h = o !== i ? o : r.height(),
                            a.apply(this, arguments)
                    }

                    if (!r[u] && this[l]) return !1;
                    var a;
                    return t.isFunction(e) ? (a = e, n) : (a = e.handler, void (e.handler = n))
                }
            }
    }(e, window),
        t('util', i)
});
layui.define('jquery', function (e) {
    'use strict';
    var l = layui.$,
        o = function (e) {
        },
        t = '<i class="layui-anim layui-anim-rotate layui-anim-loop layui-icon ">&#xe63e;</i>';
    o.prototype.load = function (e) {
        var o,
            i,
            n,
            r,
            a = this,
            c = 0;
        e = e || {};
        var f = l(e.elem);
        if (f[0]) {
            var m = l(e.scrollElem || document),
                u = e.mb || 50,
                s = !('isAuto' in e) || e.isAuto,
                v = e.end || '没有更多了',
                y = e.scrollElem && e.scrollElem !== document,
                d = '<cite>加载更多</cite>',
                h = l('<div class="layui-flow-more"><a href="javascript:;">' + d + '</a></div>');
            f.find('.layui-flow-more') [0] || f.append(h);
            var p = function (e, t) {
                    e = l(e),
                        h.before(e),
                        t = 0 == t || null,
                        t ? h.html(v) : h.find('a').html(d),
                        i = t,
                        o = null,
                    n && n()
                },
                g = function () {
                    o = !0,
                        h.find('a').html(t),
                    'function' == typeof e.done && e.done(++c, p)
                };
            if (g(), h.find('a').on('click', function () {
                l(this);
                i || o || g()
            }), e.isLazyimg) var n = a.lazyimg({
                elem: e.elem + ' img',
                scrollElem: e.scrollElem
            });
            return s ? (m.on('scroll', function () {
                var e = l(this),
                    t = e.scrollTop();
                r && clearTimeout(r),
                i || (r = setTimeout(function () {
                    var i = y ? e.height() : l(window).height(),
                        n = y ? e.prop('scrollHeight') : document.documentElement.scrollHeight;
                    n - t - i <= u && (o || g())
                }, 100))
            }), a) : a
        }
    },
        o.prototype.lazyimg = function (e) {
            var o,
                t = this,
                i = 0;
            e = e || {};
            var n = l(e.scrollElem || document),
                r = e.elem || 'img',
                a = e.scrollElem && e.scrollElem !== document,
                c = function (e, l) {
                    var o = n.scrollTop(),
                        r = o + l,
                        c = a ? function () {
                            return e.offset().top - n.offset().top + o
                        }() : e.offset().top;
                    if (c >= o && c <= r && !e.attr('src')) {
                        var m = e.attr('lay-src');
                        layui.img(m, function () {
                            var l = t.lazyimg.elem.eq(i);
                            e.attr('src', m).removeAttr('lay-src'),
                            l[0] && f(l),
                                i++
                        })
                    }
                },
                f = function (e, o) {
                    var f = a ? (o || n).height() : l(window).height(),
                        m = n.scrollTop(),
                        u = m + f;
                    if (t.lazyimg.elem = l(r), e) c(e, f);
                    else for (var s = 0; s < t.lazyimg.elem.length; s++) {
                        var v = t.lazyimg.elem.eq(s),
                            y = a ? function () {
                                return v.offset().top - n.offset().top + m
                            }() : v.offset().top;
                        if (c(v, f), i = s, y > u) break
                    }
                };
            if (f(), !o) {
                var m;
                n.on('scroll', function () {
                    var e = l(this);
                    m && clearTimeout(m),
                        m = setTimeout(function () {
                            f(null, e)
                        }, 50)
                }),
                    o = !0
            }
            return f
        },
        e('flow', new o)
});
layui.define(['layer',
    'form'], function (t) {
    'use strict';
    var e = layui.$,
        i = layui.layer,
        a = layui.form,
        l = (layui.hint(), layui.device()),
        n = 'layedit',
        o = 'layui-show',
        r = 'layui-disabled',
        c = function () {
            var t = this;
            t.index = 0,
                t.config = {
                    tool: [
                        'strong',
                        'italic',
                        'underline',
                        'del',
                        '|',
                        'left',
                        'center',
                        'right',
                        '|',
                        'link',
                        'unlink',
                        'face',
                        'image'
                    ],
                    hideTool: [],
                    height: 280
                }
        };
    c.prototype.set = function (t) {
        var i = this;
        return e.extend(!0, i.config, t),
            i
    },
        c.prototype.on = function (t, e) {
            return layui.onevent(n, t, e)
        },
        c.prototype.build = function (t, i) {
            i = i || {};
            var a = this,
                n = a.config,
                r = 'layui-layedit',
                c = e('string' == typeof t ? '#' + t : t),
                u = 'LAY_layedit_' + ++a.index,
                d = c.next('.' + r),
                y = e.extend({}, n, i),
                f = function () {
                    var t = [],
                        e = {};
                    return layui.each(y.hideTool, function (t, i) {
                        e[i] = !0
                    }),
                        layui.each(y.tool, function (i, a) {
                            C[a] && !e[a] && t.push(C[a])
                        }),
                        t.join('')
                }(),
                m = e(['<div class="' + r + '">',
                    '<div class="layui-unselect layui-layedit-tool">' + f + '</div>',
                    '<div class="layui-layedit-iframe">',
                    '<iframe id="' + u + '" name="' + u + '" textarea="' + t + '" frameborder="0"></iframe>',
                    '</div>',
                    '</div>'].join(''));
            return l.ie && l.ie < 8 ? c.removeClass('layui-hide').addClass(o) : (d[0] && d.remove(), s.call(a, m, c[0], y), c.addClass('layui-hide').after(m), a.index)
        },
        c.prototype.getContent = function (t) {
            var e = u(t);
            if (e[0]) return d(e[0].document.body.innerHTML)
        },
        c.prototype.getText = function (t) {
            var i = u(t);
            if (i[0]) return e(i[0].document.body).text()
        },
        c.prototype.setContent = function (t, i, a) {
            var l = u(t);
            l[0] && (a ? e(l[0].document.body).append(i) : e(l[0].document.body).html(i), layedit.sync(t))
        },
        c.prototype.sync = function (t) {
            var i = u(t);
            if (i[0]) {
                var a = e('#' + i[1].attr('textarea'));
                a.val(d(i[0].document.body.innerHTML))
            }
        },
        c.prototype.getSelection = function (t) {
            var e = u(t);
            if (e[0]) {
                var i = m(e[0].document);
                return document.selection ? i.text : i.toString()
            }
        };
    var s = function (t, i, a) {
            var l = this,
                n = t.find('iframe');
            n.css({
                height: a.height
            }).on('load', function () {
                var o = n.contents(),
                    r = n.prop('contentWindow'),
                    c = o.find('head'),
                    s = e(['<style>',
                        '*{margin: 0; padding: 0;}',
                        'body{padding: 10px; line-height: 20px; overflow-x: hidden; word-wrap: break-word; font: 14px Helvetica Neue,Helvetica,PingFang SC,Microsoft YaHei,Tahoma,Arial,sans-serif; -webkit-box-sizing: border-box !important; -moz-box-sizing: border-box !important; box-sizing: border-box !important;}',
                        'a{color:#01AAED; text-decoration:none;}a:hover{color:#c00}',
                        'p{margin-bottom: 10px;}',
                        'img{display: inline-block; border: none; vertical-align: middle;}',
                        'pre{margin: 10px 0; padding: 10px; line-height: 20px; border: 1px solid #ddd; border-left-width: 6px; background-color: #F2F2F2; color: #333; font-family: Courier New; font-size: 12px;}',
                        '</style>'].join('')),
                    u = o.find('body');
                c.append(s),
                    u.attr('contenteditable', 'true').css({
                        'min-height': a.height
                    }).html(i.value || ''),
                    y.apply(l, [
                        r,
                        n,
                        i,
                        a
                    ]),
                    g.call(l, r, t, a)
            })
        },
        u = function (t) {
            var i = e('#LAY_layedit_' + t),
                a = i.prop('contentWindow');
            return [a,
                i]
        },
        d = function (t) {
            return 8 == l.ie && (t = t.replace(/<.+>/g, function (t) {
                return t.toLowerCase()
            })),
                t
        },
        y = function (t, a, n, o) {
            var r = t.document,
                c = e(r.body);
            c.on('keydown', function (t) {
                var e = t.keyCode;
                if (13 === e) {
                    var a = m(r),
                        l = p(a),
                        n = l.parentNode;
                    if ('pre' === n.tagName.toLowerCase()) {
                        if (t.shiftKey) return;
                        return i.msg('请暂时用shift+enter'),
                            !1
                    }
                    r.execCommand('formatBlock', !1, '<p>')
                }
            }),
                e(n).parents('form').on('submit', function () {
                    var t = c.html();
                    8 == l.ie && (t = t.replace(/<.+>/g, function (t) {
                        return t.toLowerCase()
                    })),
                        n.value = t
                }),
                c.on('paste', function (e) {
                    r.execCommand('formatBlock', !1, '<p>'),
                        setTimeout(function () {
                            f.call(t, c),
                                n.value = c.html()
                        }, 100)
                })
        },
        f = function (t) {
            var i = this;
            i.document;
            t.find('*[style]').each(function () {
                var t = this.style.textAlign;
                this.removeAttribute('style'),
                    e(this).css({
                        'text-align': t || ''
                    })
            }),
                t.find('table').addClass('layui-table'),
                t.find('script,link').remove()
        },
        m = function (t) {
            return t.selection ? t.selection.createRange() : t.getSelection().getRangeAt(0)
        },
        p = function (t) {
            return t.endContainer || t.parentElement().childNodes[0]
        },
        v = function (t, i, a) {
            var l = this.document,
                n = document.createElement(t);
            for (var o in i) n.setAttribute(o, i[o]);
            if (n.removeAttribute('text'), l.selection) {
                var r = a.text || i.text;
                if ('a' === t && !r) return;
                r && (n.innerHTML = r),
                    a.pasteHTML(e(n).prop('outerHTML')),
                    a.select()
            } else {
                var r = a.toString() || i.text;
                if ('a' === t && !r) return;
                r && (n.innerHTML = r),
                    a.deleteContents(),
                    a.insertNode(n)
            }
        },
        h = function (t, i) {
            var a = this.document,
                l = 'layedit-tool-active',
                n = p(m(a)),
                o = function (e) {
                    return t.find('.layedit-tool-' + e)
                };
            i && i[i.hasClass(l) ? 'removeClass' : 'addClass'](l),
                t.find('>i').removeClass(l),
                o('unlink').addClass(r),
                e(n).parents().each(function () {
                    var t = this.tagName.toLowerCase(),
                        e = this.style.textAlign;
                    'b' !== t && 'strong' !== t || o('b').addClass(l),
                    'i' !== t && 'em' !== t || o('i').addClass(l),
                    'u' === t && o('u').addClass(l),
                    'strike' === t && o('d').addClass(l),
                    'p' === t && ('center' === e ? o('center').addClass(l) : 'right' === e ? o('right').addClass(l) : o('left').addClass(l)),
                    'a' === t && (o('link').addClass(l), o('unlink').removeClass(r))
                })
        },
        g = function (t, a, l) {
            var n = t.document,
                o = e(n.body),
                c = {
                    link: function (i) {
                        var a = p(i),
                            l = e(a).parent();
                        b.call(o, {
                            href: l.attr('href'),
                            target: l.attr('target')
                        }, function (e) {
                            var a = l[0];
                            'A' === a.tagName ? a.href = e.url : v.call(t, 'a', {
                                target: e.target,
                                href: e.url,
                                text: e.url
                            }, i)
                        })
                    },
                    unlink: function (t) {
                        n.execCommand('unlink')
                    },
                    face: function (e) {
                        x.call(this, function (i) {
                            v.call(t, 'img', {
                                src: i.src,
                                alt: i.alt
                            }, e)
                        })
                    },
                    image: function (a) {
                        var n = this;
                        layui.use('upload', function (o) {
                            var r = l.uploadImage || {};
                            o.render({
                                url: r.url,
                                method: r.type,
                                elem: e(n).find('input') [0],
                                done: function (e) {
                                    0 == e.code ? (e.data = e.data || {}, v.call(t, 'img', {
                                        src: e.data.src,
                                        alt: e.data.title
                                    }, a)) : i.msg(e.msg || '上传失败')
                                }
                            })
                        })
                    },
                    code: function (e) {
                        k.call(o, function (i) {
                            v.call(t, 'pre', {
                                text: i.code,
                                'lay-lang': i.lang
                            }, e)
                        })
                    },
                    help: function () {
                        i.open({
                            type: 2,
                            title: '帮助',
                            area: [
                                '600px',
                                '380px'
                            ],
                            shadeClose: !0,
                            shade: 0.1,
                            skin: 'layui-layer-msg',
                            content: [
                                '',
                                'no'
                            ]
                        })
                    }
                },
                s = a.find('.layui-layedit-tool'),
                u = function () {
                    var i = e(this),
                        a = i.attr('layedit-event'),
                        l = i.attr('lay-command');
                    if (!i.hasClass(r)) {
                        o.focus();
                        var u = m(n);
                        u.commonAncestorContainer;
                        l ? (n.execCommand(l), /justifyLeft|justifyCenter|justifyRight/.test(l) && n.execCommand('formatBlock', !1, '<p>'), setTimeout(function () {
                            o.focus()
                        }, 10)) : c[a] && c[a].call(this, u),
                            h.call(t, s, i)
                    }
                },
                d = /image/;
            s.find('>i').on('mousedown', function () {
                var t = e(this),
                    i = t.attr('layedit-event');
                d.test(i) || u.call(this)
            }).on('click', function () {
                var t = e(this),
                    i = t.attr('layedit-event');
                d.test(i) && u.call(this)
            }),
                o.on('click', function () {
                    h.call(t, s),
                        i.close(x.index)
                })
        },
        b = function (t, e) {
            var l = this,
                n = i.open({
                    type: 1,
                    id: 'LAY_layedit_link',
                    area: '350px',
                    shade: 0.05,
                    shadeClose: !0,
                    moveType: 1,
                    title: '超链接',
                    skin: 'layui-layer-msg',
                    content: [
                        '<ul class="layui-form" style="margin: 15px;">',
                        '<li class="layui-form-item">',
                        '<label class="layui-form-label" style="width: 60px;">URL</label>',
                        '<div class="layui-input-block" style="margin-left: 90px">',
                        '<input name="url" lay-verify="url" value="' + (t.href || '') + '" autofocus="true" autocomplete="off" class="layui-input">',
                        '</div>',
                        '</li>',
                        '<li class="layui-form-item">',
                        '<label class="layui-form-label" style="width: 60px;">打开方式</label>',
                        '<div class="layui-input-block" style="margin-left: 90px">',
                        '<input type="radio" name="target" value="_self" class="layui-input" title="当前窗口"' + ('_self' !== t.target && t.target ? '' : 'checked') + '>',
                        '<input type="radio" name="target" value="_blank" class="layui-input" title="新窗口" ' + ('_blank' === t.target ? 'checked' : '') + '>',
                        '</div>',
                        '</li>',
                        '<li class="layui-form-item" style="text-align: center;">',
                        '<button type="button" lay-submit lay-filter="layedit-link-yes" class="layui-btn"> 确定 </button>',
                        '<button style="margin-left: 20px;" type="button" class="layui-btn layui-btn-primary"> 取消 </button>',
                        '</li>',
                        '</ul>'
                    ].join(''),
                    success: function (t, n) {
                        var o = 'submit(layedit-link-yes)';
                        a.render('radio'),
                            t.find('.layui-btn-primary').on('click', function () {
                                i.close(n),
                                    l.focus()
                            }),
                            a.on(o, function (t) {
                                i.close(b.index),
                                e && e(t.field)
                            })
                    }
                });
            b.index = n
        },
        x = function (t) {
            var a = function () {
                var t = [
                        '[微笑]',
                        '[嘻嘻]',
                        '[哈哈]',
                        '[可爱]',
                        '[可怜]',
                        '[挖鼻]',
                        '[吃惊]',
                        '[害羞]',
                        '[挤眼]',
                        '[闭嘴]',
                        '[鄙视]',
                        '[爱你]',
                        '[泪]',
                        '[偷笑]',
                        '[亲亲]',
                        '[生病]',
                        '[太开心]',
                        '[白眼]',
                        '[右哼哼]',
                        '[左哼哼]',
                        '[嘘]',
                        '[衰]',
                        '[委屈]',
                        '[吐]',
                        '[哈欠]',
                        '[抱抱]',
                        '[怒]',
                        '[疑问]',
                        '[馋嘴]',
                        '[拜拜]',
                        '[思考]',
                        '[汗]',
                        '[困]',
                        '[睡]',
                        '[钱]',
                        '[失望]',
                        '[酷]',
                        '[色]',
                        '[哼]',
                        '[鼓掌]',
                        '[晕]',
                        '[悲伤]',
                        '[抓狂]',
                        '[黑线]',
                        '[阴险]',
                        '[怒骂]',
                        '[互粉]',
                        '[心]',
                        '[伤心]',
                        '[猪头]',
                        '[熊猫]',
                        '[兔子]',
                        '[ok]',
                        '[耶]',
                        '[good]',
                        '[NO]',
                        '[赞]',
                        '[来]',
                        '[弱]',
                        '[草泥马]',
                        '[神马]',
                        '[囧]',
                        '[浮云]',
                        '[给力]',
                        '[围观]',
                        '[威武]',
                        '[奥特曼]',
                        '[礼物]',
                        '[钟]',
                        '[话筒]',
                        '[蜡烛]',
                        '[蛋糕]'
                    ],
                    e = {};
                return layui.each(t, function (t, i) {
                    e[i] = layui.cache.dir + 'images/face/' + t + '.gif'
                }),
                    e
            }();
            return x.hide = x.hide || function (t) {
                'face' !== e(t.target).attr('layedit-event') && i.close(x.index)
            },
                x.index = i.tips(function () {
                    var t = [];
                    return layui.each(a, function (e, i) {
                        t.push('<li title="' + e + '"><img src="' + i + '" alt="' + e + '"></li>')
                    }),
                    '<ul class="layui-clear">' + t.join('') + '</ul>'
                }(), this, {
                    tips: 1,
                    time: 0,
                    skin: 'layui-box layui-util-face',
                    maxWidth: 500,
                    success: function (l, n) {
                        l.css({
                            marginTop: -4,
                            marginLeft: -10
                        }).find('.layui-clear>li').on('click', function () {
                            t && t({
                                src: a[this.title],
                                alt: this.title
                            }),
                                i.close(n)
                        }),
                            e(document).off('click', x.hide).on('click', x.hide)
                    }
                })
        },
        k = function (t) {
            var e = this,
                l = i.open({
                    type: 1,
                    id: 'LAY_layedit_code',
                    area: '550px',
                    shade: 0.05,
                    shadeClose: !0,
                    moveType: 1,
                    title: '插入代码',
                    skin: 'layui-layer-msg',
                    content: [
                        '<ul class="layui-form layui-form-pane" style="margin: 15px;">',
                        '<li class="layui-form-item">',
                        '<label class="layui-form-label">请选择语言</label>',
                        '<div class="layui-input-block">',
                        '<select name="lang">',
                        '<option value="JavaScript">JavaScript</option>',
                        '<option value="HTML">HTML</option>',
                        '<option value="CSS">CSS</option>',
                        '<option value="Java">Java</option>',
                        '<option value="PHP">PHP</option>',
                        '<option value="C#">C#</option>',
                        '<option value="Python">Python</option>',
                        '<option value="Ruby">Ruby</option>',
                        '<option value="Go">Go</option>',
                        '</select>',
                        '</div>',
                        '</li>',
                        '<li class="layui-form-item layui-form-text">',
                        '<label class="layui-form-label">代码</label>',
                        '<div class="layui-input-block">',
                        '<textarea name="code" lay-verify="required" autofocus="true" class="layui-textarea" style="height: 200px;"></textarea>',
                        '</div>',
                        '</li>',
                        '<li class="layui-form-item" style="text-align: center;">',
                        '<button type="button" lay-submit lay-filter="layedit-code-yes" class="layui-btn"> 确定 </button>',
                        '<button style="margin-left: 20px;" type="button" class="layui-btn layui-btn-primary"> 取消 </button>',
                        '</li>',
                        '</ul>'
                    ].join(''),
                    success: function (l, n) {
                        var o = 'submit(layedit-code-yes)';
                        a.render('select'),
                            l.find('.layui-btn-primary').on('click', function () {
                                i.close(n),
                                    e.focus()
                            }),
                            a.on(o, function (e) {
                                i.close(k.index),
                                t && t(e.field)
                            })
                    }
                });
            k.index = l
        },
        C = {
            html: '<i class="layui-icon layedit-tool-html" title="HTML源代码" lay-command="html" layedit-event="html"">&#xe64b;</i><span class="layedit-tool-mid"></span>',
            strong: '<i class="layui-icon layedit-tool-b" title="加粗" lay-command="Bold" layedit-event="b"">&#xe62b;</i>',
            italic: '<i class="layui-icon layedit-tool-i" title="斜体" lay-command="italic" layedit-event="i"">&#xe644;</i>',
            underline: '<i class="layui-icon layedit-tool-u" title="下划线" lay-command="underline" layedit-event="u"">&#xe646;</i>',
            del: '<i class="layui-icon layedit-tool-d" title="删除线" lay-command="strikeThrough" layedit-event="d"">&#xe64f;</i>',
            '|': '<span class="layedit-tool-mid"></span>',
            left: '<i class="layui-icon layedit-tool-left" title="左对齐" lay-command="justifyLeft" layedit-event="left"">&#xe649;</i>',
            center: '<i class="layui-icon layedit-tool-center" title="居中对齐" lay-command="justifyCenter" layedit-event="center"">&#xe647;</i>',
            right: '<i class="layui-icon layedit-tool-right" title="右对齐" lay-command="justifyRight" layedit-event="right"">&#xe648;</i>',
            link: '<i class="layui-icon layedit-tool-link" title="插入链接" layedit-event="link"">&#xe64c;</i>',
            unlink: '<i class="layui-icon layedit-tool-unlink layui-disabled" title="清除链接" lay-command="unlink" layedit-event="unlink"">&#xe64d;</i>',
            face: '<i class="layui-icon layedit-tool-face" title="表情" layedit-event="face"">&#xe650;</i>',
            image: '<i class="layui-icon layedit-tool-image" title="图片" layedit-event="image">&#xe64a;<input type="file" name="file"></i>',
            code: '<i class="layui-icon layedit-tool-code" title="插入代码" layedit-event="code">&#xe64e;</i>',
            help: '<i class="layui-icon layedit-tool-help" title="帮助" layedit-event="help">&#xe607;</i>'
        },
        w = new c;
    t(n, w)
});
layui.define('jquery', function (e) {
    'use strict';
    var a = layui.$,
        l = '';
    e('code', function (e) {
        var t = [];
        e = e || {},
            e.elem = a(e.elem || '.layui-code'),
            e.about = !('about' in e) || e.about,
            e.elem.each(function () {
                t.push(this)
            }),
            layui.each(t.reverse(), function (t, i) {
                var c = a(i),
                    o = c.html();
                (c.attr('lay-encode') || e.encode) && (o = o.replace(/&(?!#?[a-zA-Z0-9]+;)/g, '&amp;').replace(/</g, '&lt;').replace(/>/g, '&gt;').replace(/'/g, '&#39;').replace(/"/g, '&quot;')),
                    c.html('<ol class="layui-code-ol"><li>' + o.replace(/[\r\t\n]+/g, '</li><li>') + '</li></ol>'),
                c.find('>.layui-code-h3') [0] || c.prepend('<h3 class="layui-code-h3">' + (c.attr('lay-title') || e.title || 'code') + (e.about ? '<a href="' + l + '" target="_blank">layui.code</a>' : '') + '</h3>');
                var d = c.find('>.layui-code-ol');
                c.addClass('layui-box layui-code-view'),
                (c.attr('lay-skin') || e.skin) && c.addClass('layui-code-' + (c.attr('lay-skin') || e.skin)),
                (d.find('li').length / 100 | 0) > 0 && d.css('margin-left', (d.find('li').length / 100 | 0) + 'px'),
                (c.attr('lay-height') || e.height) && d.css('max-height', c.attr('lay-height') || e.height)
            })
    })
}).addcss('modules/code.css', 'skincodecss');
